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Pin Name |Type} Comments 


Pint 
ES IVSSE 



















Pp +429 [ups | B [uCoMDaa bs | 

2 [Raps | 0 [RAMAddressBus [30 [vsse [P|] id 
3 [rap 0 | P31 [up7 | B [eCOMDea Bus | 
v4 [RaDI2 | 0 | P32 [URS [1 |uCOM Register Selew 
rs [RAD | 0 | 33 [URD- | I |uCOM Read Swote | 
Te [RADIS_| 0 | P34 [uwR- [1 [uCOM Write Strobe 
Pr [vsse fp | 35 Jucs. [1 [ucom chip setexr _| 
UINT. | 0 [uCOM Intemupt | 


5 





Ce Demi eie — emeee| a e e 
110 [DBCK | 1 {Serial Bit Clock CS3FX_ | 1 | 
fui [pcapo_| 1 |C2Pointerinput_ | 39 | CSiFx | T | 
[12 [RDPAR | B |RAMParityData | 40 [HA2 | I 
Ee ISIMCK e108 e a. SAE DD. Se 
| i4 [xouT | 0 [xX'alosc Output | 42 [HAO | 1_ [IDE Host Interface 
pis [XIN | 1 [Xtal osCimpa__| 43 | HPDIAG| B 
jio|vsst | P| 4 [HA CT 
a7 |sBs0—|_1 |Suboode imerface [45 [rocsié. | 0 | 
ris [week [1 | mee |e 
[47 | HIRQ__[_O_|IDE Host Interface 
[20 [exck | B | 
[21 |vpp_ fei 49 | orpy | 0 | 
P22 fubo |B [aCoMDaabos [50 faRD. [1p 
23 jubi__| B | rst [vsse P| 
[24 |vsse_ | P| 52 |HWR |_| IDE Host Interface 
[a3 fub2 | B [aCoMDaamus [53 | HDRO_| 0 
[26 [ups | B [54 |HDIS | B 
a7 jobs | 8 | [ss[HDo | B IDE How Dara Bus 
2s [ups [3 | rss [wie |B | 


FIG. 3b 
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Pint [Pin Name [Type|Commens [Pin] Pin Name[Type|Commens | 
P57 [D1 |B |IDEHoxDawBus | 79 [RDG | B [RAMDataBus | 
rse[vsse [P| ssid eo vsse [Pr] Cd 
39 [HDIS |B [DDEMoaDaaBus [81 [Rs |B |RAMDau Bus 
roo laste [1] —S—S—~d a |? 


teste Eee een 









rez [api | 8 P84 [ROE | B [RAMRead Enable | 
re [ups | B | Pas [RDO |B [RAMDataBus | 
[64 [vss [Pp] ste fvsse [| Pt 
r6s fupit | B |DEWosDaaBus [87 [RDI |B [RAMDaaBu 
[66 |vssE | P| 88 | RWE- | O |RAMWrite Enable | 
ro7 [aba |B [DEHoxDaaBu [eo|vpbo {P| 
res [ADO | 8 | [90 [RADIA _|_O_|RAM Address Bus 
ro [HDs | 8 | ror [RADS | 0 | 

[70 |HD9 | B | 92 |RAD8_ | O | 

[71 [HDs |B | | 93 |RAD7_ | O | 

Ta [vsse__[ P| +i 94 [vsse_| P| 

| 73 |HDs =| BY IDE Host Data Bus 195 |RAD6 | O | RAM Address Bus 
[74 {HD7 | B | 96 |RADS_ | O | 

[7s [reser | 1 [|| 97 |RaDa_| 0 | 

[76 |RD* | B [RAMDaaBus | 98 |RADO_ | © | 

[77 |RDs_ | B | [99 |RADI_ | 0 | 

[78 |RD7___| B | }100 | RAD2_ | O | 
















FIG. 3c 
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[Pin Name |Pin Type _| 













Pin Description 


uCONTROLLER DATA BUS - Microcontroller bidirectional data 
bus. This bus is compatible with most microcontrollers. 


uCONTROLLER REGISTER SELECT - Register select input. AR 


(address register) is selected if URS=0. Otherwise, microcontroller 


Ee 
will access the internal register that is pointed by the AR register. 


[IN ___ | CONTROLLER READ STROBE - Microcontroller read strobe. 
fUWR- [IN _— JuCONTROLLER WRITE STROBE - Microcontroller write strobe. __| 
lucs- [IN [wCONTROLLER CHIP SELECT - Microcontroller chip select input. _| 
OUT/ uCONTROLLER INTERRUPT - Microconireller interrupt output. 

Open-Drain 


This is an open-drain ouput. This signal can be externally wired - 
OR with other interrupt sources. 
FIG. 4 
in Name ——_Pin Type! Pin Descripti 
HOST DATA BUS - Host Bidirectional Data Bus. 
IHWR-——s«[IN._ | HOST WRITE STROBE - Host IO write strobe. 
HRN HOST READ STROBE - Host IO read strobe. 


HA2-HAO HOST ADDRESS - These are the 3-bit Host Addresses asserted 
by the host to access a register or data port in the OTI-011. 


IOCS16- OUT/ DRIVE 16-bits I/O - For PIO transfer, IOCS16- indicates to the host 
es system that the 16-bit data port has been addressed and OTI-011 
is prepared to send or receive 16-bit data word. 












































CS1FX- IN HOST CHIP SELECT 1 - This is the chip select signal decoded 
from the host address bus used to-select ues Command Block 
registers in the OTI-011. 

CS3FX- HOST CHIP SELECT 3 - This is the chip select signal decoded 
from the host address bus used to select the Control Block 
registers in the OTI-011. 














HDRQ OUT HOST DMA REQUEST - This signal will be asserted for DMA data 
transfer when OTI-011 is ready to transfer data to or from the host. 
This signal is used in a handshake manner with DMACK-. When a 
DMA operation is enabled, data transfers are 16-bits wide. 


ae HOST DMA ACKNOWLEDGE - This signal is used by the host in 
response to HDRQ. 


Fae heat HOST INTERRUPT - This signal is used to interrupt the host system. 
IORDY OUT HOST IO READY - This signal is asserted to extend the host transfer 


cycle of any host read access when the OTI-011 is not ready to 
respond to a request. 

a 

Ria 















HOST DRIVE ACTIVE/DRIVE 1 PRESENT - This is a time- 
multiplexed signal which indicates that a drive is active, or 
that Drive 1 is present. This signal is controlled by the firmware. 
HOST PASSED DIAGNOSTICS - This signal is asserted by Drive 1 
to indicate to Drive 0 that it has completed diagnostics. This signal 
is controlled by the firmware. 


FIG. 5a 
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Addresses 


Control block registers 


TN [ON [x [x [x [Daw barhigh impedance | NotUsed | 
TN [ A [1 [1 | 0 | Alternate ATAPI tans | Device conxal ___| 
TN [a_i [1 [1 [Brive Address | Noted sd 
a 
TN [oo ]0 [bei mS SC~S 
af N [0 [0 | 1 [ATAPI EnorRegiser | ADAPIFeaures | 
Ta [ON [0 [1 [0 | ATAPI interrupt Reason Regiser RW) | 
Ta DN [o [1 [1 [Noted | Nosed ds 
"a [ON [2 [0 [0 | _ATAPIBye Count Register G70) UW) __| 
Ta TON [1 [0 | 1 | ATAPI Byte Count Register (bit 15-8) (VW) _| 
Ta [ow ta [a fe] Driveseiecr RW) 
a [a bx px [x [avalid address” | valid Address | 


Logic conventions are: A = signal asserted, N = signal negated 


FIG. 5b 










> 








>> [> p> p> 


> 













DSDATA 


Pin Description 


DSP SERIAL DATA - This serial input receives the data from DSP 
(CIRC decoder). The DBCK pin provides the data clock to the 
OTI-011. The received data are stored in the buffer RAM. 


DBCK DSP BIT CLOCK - This clock input receives bit clock from DSP. 


DLRCK DSP L/R CLOCK - Supplies the signal which is used to distinguish 
L-channel/R-channel (44.1KHz) DLRCK signal also indicates the 
start timing of 16 bit PCM word. 

DC2PO IN DSP C2 POINTER - Supplies C2 error flag signal from DSP. When 

- high, DC2PO indicates an error condition. 
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SBSO SUBCODE SERIAL DATA - Supplies Subcode serial data. The 
subcode words (P-W) will be stored into buffer RAM in the order. 
— SUBCODE SYNC - Supplies Subcodes SYNC from DSP. 
ia EXTERNAL CLOCK - Supplies Bit Clock for Subcode interface. 
This ee can be programmed as input or output. 


FRAME CLOCK - Supplies Write Frame Clock from DSP. 
(7 OC S5KELS 


FIG. 7 













Pin Type [Pin Description 


aA : 5- RAM ADDRESS BUS - Buffer RAM address outputs. 
RA 


RDPAR RAM PARITY DATA - RAM Parity bit when RPEN = 1. 
RAM DATA BUS - Buffer RAM data bus. 


RWE- OUT RAM WRITE ENABLE - The OTI-011 forces this pin low when 
writing data to the RAM. 


RAM OUTPUT ENABLE - The OTI-011 forces this pin low when 
reading data from the RAM. 


FIG. 8a 
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Miscellaneous Pins 


Pin Type | Pin Description 


XIN IN XTAL INPUT/XTAL OUTPUT - XIN, XOUT are normally 
XOUT OUT 
MCK 


connected to a crystal. (up to 21MHz) XIN pin may be driven 
re 















by the external signal. (21 MHz max. 45-55% duty) The OTI-011 
contains an internal resister between XIN and XOUT, so that 

an external resister shall not be connected to these pins. 
M CLOCK - This output supplies clock signal! of one-half the crystal 
eo |e when register bit MCK1 is low. When register bit MCK1 



















is high, MCK pin supplies crystal frequency. 
CLKSTP  |IN _ |CLOCK STOP - CLKSTP stops the internal clock, when it is high. 
reset by either this reset signa! or the internal reset command 
(Writing RESET register). RSSTAT register shows user which 
[vDD___| | Supplies 5.0V-+/- 5% 
VSSEIVSSI_||GroundPins  SSSSOSCSCSCSCSCSC‘C‘~* 


RESET- IN RESET - Forcing this input low reset the OTI-011. OTI-0O11 can be 
reset most recently took place. 





AR - Address Register 


fAddress[Type] Bik? | BO | BRS | BRA | BeS | BRD | BRI | BRO | 
ia 


address 


Fo - | wl address 
FIG. 10 





COMIN - Command Packet Register 


|Address|Type| Bit-7 | Bit6 | Bits | Bits | Bit3 | Bit2 | Bit | Biro | 
Gr ance a 
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IFSTAT/IFCTRL - Interface Status Register/Interface Control Register 


Address 
oth |_R | eméib | tei | decib |x | atbsyd |x | atenb 
oth] W [emdien [detsien | deoien | o | 0 | 0 {dowen | 0 | 




















DBCL - Data Byte/Word Counter 


[Address[Type| Bit-7 | Bit-6 | Bit-5 | Bit | Bit-3 [ Bit2 | Bit1 | Bito_| 
[om | R | oz | v6 | bs | bs [ 3 | v2 | br | vO | 
| o2h | w{ 7 | v6 | bs | 4 bs | b2 | bl | bo | 













DBCH - Data Byte/Word Counter 
[Address[Type] Bit-7 [ Bit-6 | Bits | Bits | Bit-3 | Bit-2 | Bitl | Bito 
| o3h | R | atei_ | dtei_ | atei_| tei | bir | bio | 9 | o8 | 
yon {wit o | o | o {| o [bu | vio [| 9 | 8 | 


FIG. 14 


raddress[Type| Bic? | Be | Bes | Ba | Bis | BRD | BRI | BiCO | 
rom | R 


header minutes (bcd) 
P oan [wl az | a6 fe ee De ee 













a5 


FIG. 15 


a4 











[Address[Type| Bit-7 [ Bite | Bits | Bis | Bie3 | Bit2 | Bit-1 | Bit-o | 


| 05h | R header seconds (bcd) 
| osh | wliais | al4 | a3 | ai2 | all | ee ee 


FIG. 16 
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HEAD2/DTTRG - Header Registers/Data Transfer Trigger 


[Address [Type] Bic? | Bi-6 | BRS | Bie | BRI [ Be2 | Ba | BRO 
| 06h | R | header frames (bcd) 
(data unused) 


FIG. 17 






[Address [Type] Bit? | Bi-6 | Bus | Bia | Bud | BED | Bel | BRO 
| Oth | R | header mode (bed) 
(data unused) 


FIG. 18 











STARTING POINT MODE 1 (MODRQ=0) | MODE 2 (MODRQ=!1) 
First Sync Byte FF,FOh FF,E8h 





First Header Byte FF,FCh FF,F4h 
First Subheader Byte es ee eel FF,F8h 
First User Data Byte 


FIG. 19 










‘Address [Type] Bic? | Bio | BRS | Bia | BRS | BRO | BRI | BRO | 
Posh [| Ra? [ a6 [| as | at | | a | at | 
[cosh [wl oa [ a fo as [ a4 | a | a [ at | a0 | 


FIG. 20 


Address [Type] Bie? [Bao | Bis | Bea | BRS | BRD | Biel] BRO | 
ron | Rk] ais | aa [a3 [az | an | a0 | 9 | 08 
oom [wl] ais | aid [ais | az | an | ao | 9 | 0 


FIG. 21 
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WAL/CTRLO - Write Address Counter/Control 0 Register 


fAddress[Type| pic? [ Bi-é [ Bis | Bi-4 [ Bit3 | Bit? | Biel | Bio | 
(ee ee a 
| 0 | eO irq | autorg [weg | arg | pra | 



























RQ HEADO-3, 
h.5 SUBHO-3 
04-07h, 14-17TH) 
Tafa [1 [1 [ 1 | QPeomection | Valid | BufferRAM | 
Tafa ft | 1 [0 | Qcorection | valid | BufferRAM | 
mat ft fo [1 | Peorection | valia_[ BufferRAM _| 
(no ECC) 
Pr {| o [| x | 0 | 0 _ | Disk-monitor Invalid 
ra fo | x [| x [ 1 | Notrecommended | | (seenote) | 
raf o [| x | 1 | x | Notrecommended [| (seencte) | 
fo |x | x | x | x | Decoderdisabled | invalid | Invalid 













WAH/CTRLI - Write Address Counter/Control 1 Register 


raddress| Type] Bic? | Bité | Bes | Bit Bie | Bio 
“on TR ais tam [a [ae | an | ao | 9 | 8 | 
Toph [Low [syien “| syden | dscren [cowren | modrq_| formrg 


FIG. 24 


STATO/PTL - Status 0 Register/ECC Block Pointer 


Bie 
och | R [creak | syne [-nosyne | Tbik | wshort | sbtk [0 | ucebik 
oe twa ts ta [aw | 3a | 2 | a | 0 | 


FIG. 25 
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SYIEN | SYDEN SYNC ILSYNC | NOSYNC LBLK SBLK 
OBh.7 OBh.6 OPERATION 0Ch.6 0Ch.5 O0Ch.4 0Ch.2 
1 Sync-insertion active active inactive inactive 
+detection 
Sync-insertion inactive active inactive active 
only 
only 


FIG. 26 
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ae Status | —— Block Pointer 
ar A ee 
| oph | wf ais | al4 | 









pases[ Tree] BicT [oes [pes [met [os [pea [oer [oo | 
air [-R | mod [mod] emodT| mod | mode | nocor | coi | vformt | 
oe ee 





FIG. 28 


rAddress[Type] Bie? | BRO [ Bis | Bea | Be | BRD | Bei | BRO | 
i TT 
|_OFh | W_| (data unused) 





FIG. 30 











Boe os eae ee ae ee ee 
10h | wf o | swen | sdss | dekke | 0 | 0 | 0 | 0 


FIG. 31 










CRTRG 


Rs ee ee ee 
Sane oR foo ee eee 
Tim twlelojypo)]o]o |] 0 | 0 | om | 
FIG. 32 
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Php R[ mse CSC“~s~S*~* 
an Pw amused SCSC—“—Ss—Ss~S 
FIG. 33 











5s Be aaa ed 
PW a eae hc en ee OE Se ee en 
FIG. 34 










ian [Rk | ____subheader flemumber 
Ae 2 
FIG. 35 


igh [R | __-subheader channel mumber 
ise bw tse SSCS 


















SUBH2 

rAddress|Type] Bi7 | Be | BeS | Bea | Bid | BRD | BRI] BRO | 
Piéh | R | ____subheader submode number 
ian wel ce amd ee 












SUBH3 . 
Te 
Pam LR | ___subheader coding information 
im twtr SC—C—s—SCS 
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Buffered | SUBHO | dontcare | buffered byte 20 
SUBHI 
SUBHI 
SUBH? 
SUBHS 
dont care 


FIG. 39 












DSPSL 


rAddress[Type| Bic? | Bice [Bits | Bea | BRS | BR? ] Bel] BRO 
ime ee 
Pipe [Tw | ct [setio [ier [0 [0 | seit [a | edee 
FIG. 41 
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UD7 | UD6 | UDS | UD4 | UD3 | UD2 | UD: | UDO DSP 
c2mi | sell60 | Ichl x X sell6 dir edge Type 
Hd A lean 
Oe a all OR We OB 
ied tee 
et Ae 


FIG. 42 














[Address |Type| Bit7_| ito [ Bits | pies | Bit-3 | Bic2 | Biel [| Bito | 
Ce ae eae ee ee 











Address] Type] Bic? | Bié [BRS | Bea | BS | BRO [BRI] BRO” 
Pipa | R 


| iBh | W | ciml | sett6o | ichi [ x Tx | seli6 | dir | edge | 






FIG. 44 











ae SBT ae oo —— a 
[ich | R [0 | spare | spare | spare | ats | srg] loki] dmaié | 
Puen Wei tas [a aes 


FIG. 45 
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UACH 


rAdéress[Type| Bie? | BRO | BeS [| Bea | BRS | Be? | Biki | BRO | 
1 eee OOPS, Ves en EE 


fun | wats | aia | a3 {| az | au | aio | a | 8 





FIG. 46 


UACU 


Address|Type| Bit-7 | Bit-6 | BicsS | Bits | Bir3 | Bie2 | Bit | Biro | 
once ee ee ee ee ee ee 


FIG. 47 










RAMRD/RAMWR 


AdGess Type] BRT [BRS [BRS [one [BES [BRS [BT | BRO] 
BT 
| teh | wlio? | we | ws | mwa | rw3 | rw? | wi | rw 


FIG. 48 


fAdaress[Type] Bie? | BO | BRS [ Baa | BRS | BRD | BRI | BuO | 


| iFh | R | urtbsy | csi3_ | 0 | o | o | o | hw | 0 | 
| ifn | w | udwg | udata | hostio | o [ 1 [| 1 [ o | o | 





FIG. 49 


Bis | Bit? | Bit | Bitco 


FIG. c 
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HICTL 


| 20h_| w | 0 | pdiagen | daspen | clrbsy | setbsy | scod_| iordyen [iocsi6en, 


FIG. 51 





| 2in {wt o {[ o { o | © | nopq | cdsp2 | cdspi_| cdspo_| 


FIG. 52 














21h.2 21h.1 21h.0 Rate 
0d AR OS Blocksrse) 
| | 4X (300 blocks/sec) | 
es eee 


SSK are eee, Re, 
cares comecien aaneery eee) 





STATS 


|Address|Type| Bit-7 | Bit-6 | Bits | Bit4 | Bit-3 | Bir2 | Bit-1 | Biro | 


| 22h | R| -dataunused | missy | sbkend | silsy _| 
data unused 


FIG. 54 
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DBACL 


|Address|Type| Bir7 | Bit-6 | Bits | Bit | Bits | Bit2 | Biri | Biro _| 
| 24m | wi 7 | ve {| os | bs | bs [| 2 7 oi | bo | 


FIG. 55 


|Address|Type| Bit-7 | Bit-6 | Bits | Bins | Bit3 | Bit2 | Biel | Bito_| 
pe woo oie fe eT a 









FIG. 56 






rAddress|Type] Bie? | Bi-6 | Bid | Baa | BRS | BRO] BRI | BRO | 
BET RT 


FIG. 57 





SBKH 


<a 


data unused 





FIG. 58 





fAdaress[Type| Bi? | Bicé | BaS [ Baa | BRI | BRD | Bel | BRO 
Gea a 


FIG. 59 


WBKH 


data unused Pos | 


FIG. 60 
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raddress|Type| Bie? [| Bice | Bes | Bra | BES] Bi? | BRI | BRO | 
an LR [oftyp [rameir | ramO | uhifo | mpen [ro [rofl | raf _| 
aan Cw [sfyp [rameir | 0] bilo | men_| rom [refi [ref _| 


FIG. 61 


RCF2 RCF1 RCFO RAM Configuration 
2Ah.2 2Ah.1 2Ah.0 


















Poo TCT 228K DRAM (256K X 4-bit X 1) 
ae ae | | 256K DRAM (256K X 4-bit X 2) 










MEMCE - Memory Layout Configuration Register 


Adiress[Type] Bic? | Bice | Bis | Baa [BRS | BR? | BRI | BRO 
zen Tw to fo | 0 [0 | purg | iorayt [_miyi | mlyo_| 


FIG. 63 


DRAM Memory Layout Configuration 


Data Blocks + Last 2 Auxilary/Subcode Blocks 
Data Blocks + All Auxilary/Subcode Blocks 


FIG. 64 

















20m _Lw [sbxek | soen | soba | scien | exinv | exop | sbsett | sbsel0_| 


FIG. 65 
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SBSEL1 ee Subcode Format 
2Ch.1 


ee ee SMDO (Philips) 
ee ee ee eee SMD1 (EIAJ-1) 











SMD2 (EIAJ-2) 
Undefined 






Adare Type] Bie? | Bi6 | BRS | Bice | BRS | Be? [Bel | BRO 
Pmeh fT Riot | te ft tt tt diag | daspb_| 
| 2Eh | w | ideien | 0 | drveb | drvib | hintg | 0 | 0 | 0 | 


FIG. 67 






ies oe[ ie? [ws [aes [ wie [os [wee [we [a 
eee Soe ee 












Bit | Bit-O_| 
ST a NC 
| 3th [wf 7 | 6 | bs | ba | mer { abr | com | ili | 





FIG. 69 
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sam TrwP oo | o | o | o | 0 | 0 | wo | ca _ 





FIG. 70 






ATSPA 
Pas tewlo | 0 | © | 0 [0 J o | 0 [1 


FIG. 71 









Yah TRw] b7 [vo [os | o | wa | v2 | or | v0 | 


FIG. 72 









‘Address[Type] Bi? | Be | BeS | Bed [| Bed | BRO | Bei] BRO 
rash [ew] o7 | s6 [ts [| ots [ o2 | v1 | v0 | 





FIG. 73 






ATDRS . 
rAddress| Type] Bie? | Bao [ Bus | Baa | BRS | BR? | BRI | BRO 
[a _[ew] 1 | 1 | i-| a |[o fo {fo ]o_ 


FIG. 74 
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Addres|Type] Bk? | BRO | BRS | Bea | BRS | BRD | Biel | BeO_ 
i 6S a 9 
am fw [0 | arey [0] ate [arg [comm [0 | eheck 






[Address|Type| Bit-7 | Bit-6 | Bits | Bir4 | Bit-3 | Bit-2 | Bici | Bit-O | 
4oh_| wf} 7 | b6 | bs | bs | 3 J v2 [ or [bo | 









aes ips] BET [owe [aes [Ba oe [ae RT 
CST eG OT 


FIG. 77 


| 42h [wii] b7 | be | os [ tb | os [ b2 [ oi | to | 


FIG. 78 















rAddres[Type| BRT | BRé | BRS [Bid | BRI [BRD | BRI] BRO | 
Cael eee oe ee 


FIG. 79 
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Be? | Biel 


| 44n [wf] 7 | v6 [| os [oo fos Too To 









| 45h [wi] 7 | be | 5 [ oe | os | be | bi | bo | 











ae ST ae Oa a _—n 
- aon |w | e7 | v6 | ts | vo | vs | v2 | bi] to] 









[4m [wl] o7 | v6 | ts | ts [3 | v2 | ot | wo 


FIG. 83 
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OPTICAL DRIVE CONTROLLER WITH A 
HOST INTERFACE FOR DIRECT 
CONNECTION TO AN IDE/ATA DATA BUS 


This application is a continuation of U.S. patent Ser. No. 
08/264,361, filed Jun. 22, 1994, now USS. Pat. No. 5,581, 
715. 


BACKGROUND OF THE INVENTION 


1. Field of the Invention 


This invention relates generally to the access of digital 
data from optical storage media by a personal computer. 
Optical storage methods allow information to be recorded 
and recovered from a given material by using light. The 
compact disk (CD) media currently used in optical recording 
is capable of significantly higher areal density than magnetic 
disks. This capacity to store a large amount of information 
per unit area of the media surface is a major advantage of CD 
technology over magnetic disk storage techniques. 

2. Prior Art 


The field reliability of CD systems is yet to be determined 
due to the relatively short period of time this media has been 
in use. However, optical recording systems are expected to 
be more reliable than magnetic disk drives, generally 
referred to as hard disks, for several reasons. The optical 
heads used for recording and recovering information are 
spaced away from the disk at all times, eliminating the 
possibility of head crashes. And the optical techniques used 
cause no wear or tear on the media surface during reading or 
transferring of information. 

The reliability characteristic of optical storage media 
appears to be especially advantageous where the removabil- 
ity and transportability of the media is critical. Compared to 
magnetic disk drives, both hard and floppy, the operation of 
a CD is much less sensitive or affected by dust accumulation 
on either the head or the media. And the optical methods of 
reading and writing data without making physical contact 
with the media surface significantly reduces the potential for 
damage in removable disk applications. 

The integration of CD drives into personal computers 
comprises one of the largest markets for optical storage 
media applications for the foreseeable future. At present, the 
cost of a CD drive is a primary barrier to the growth of this 
market. However, the CD-ROM (read only memory) stan- 
dard as originally developed by Sony and Phillips has 
become the standard defining the physical characteristics 
and disk format for data storage and retrieval. This format 
has become very popular for making large amounts of 
information available to users at a relatively low cost and 
there is an increasingly large library of CD-ROM titles 
available. CD drives which are capable of writing informa- 
tion to the CD are much less widely used today due to their 
much greater cost and complexity. 


All CD drive designs include a CD load mechanism, a 
spindle, drive electronics and a controller. The drive elec- 
tronics recovers data from the CD as directed by the con- 
troller. The controller manages the flow of commands, status 
flags and data between the host personal computer and the 
CD drive electronics. 


Conventional CD drive designs support the Industry Stan- 
dard Architecture (ISA) bus convention and require the 
insertion of an interface card or host adapter card into an ISA 
input/output bus slot of the host personal computer. These 
disk drive designs include a variety of proprietary and 
manufacturer specific designs as well as designs that support 
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the three varying software driver formats used with the 
Small Computer Systems Interface (SCSI) standard. These 
three software driver formats include Microsoft’s Layered 
Device Driver Architecture, the American National Stan- 
dards Institutes’ Common Access Method, and the 
Advanced SCSI Programming Interface. 

A SCSI disk drive includes a controller and a SCSI slave 
interface. A SCSI disk drive communicates with a host 
computer through a SCSI host adapter card which must be 
resident on the ISA bus of the host. There are three types of 
host adapter cards, namely a register compatible controller, 
an INT 13h compatible controller, and an installable device 
driver. These types of host adapter designs are fully 
explained in widely available technical publications. 

The reliance of all conventional CD drive designs exclu- 
sively on the use of the ISA input/output bus results in the 
additional expense of host adapter card electronics. 
Furthermore, a reduction in the range of employment of any 
given computer system due to the permanent commitment of 
an input/output bus slot to communication with the CD drive 
controller is a limitation in the prior art. 

An alternative bus structure is available within standard 
personal computer architecture available for use with a CD 
drive controller. This structure is referred to as integrated 
drive electronics with an AT attachment interface, or IDE/ 
ATA. The American National Standards Institute has pub- 
lished this standard and it is currently widely available. The 
term integrated drive electronics includes any drive with a 
controller included. For example, all SCSI drives are in fact 
IDE drives. The term IDE/ATA applies to a drive if and only 
if its interface conforms to the industry standard AT attach- 
ment specification. IDE/ATA drives do not take up an ISA 
input/output slot. This class of interface is connected by 
means of a dedicated 40 pin connector found on many 
personal computer mother boards. 


Conventional CD drives in the prior art failed to make use 
of the IDE/ATA bus. However, now that the AT standard has 
become widely used in many personal computers, it would 
be desirable to provide a CD drive with built-in controller 
functionality and a standard connector. This would obviate 
the need for an additional host adapter card and associated 
electronics. Providing these electronics in addition to the CD 
drive itself increases the overall cost of a system using a CD 
drive for data storage and retrieval and also makes a CD 
drive more complicated to install on existing personal com- 
puters in use today. Due to the plethora of methods of ISA 
interface designs used in the industry today, compatibility 
issues often occur when, for example, a particular CD drive 
controller is tasked with communicating with another ISA 
bus connected peripheral device. The high frequency of 
incompatibility often prohibits the employment of the most 
cost efficient or highest performance combination of 
devices. The present invention, a controller for CD drives 
which can be implemented with a drive using a standard AT 
connector, overcomes the problems associated with the prior 
art as will be made clear in the following discussions 
thereof. 


SUMMARY OF THE INVENTION 


This invention relates to a compact disk drive controller 
for a compact disk drive to control the communication of 
digital information between a compact disk to a host com- 
puter. The compact disk drive would generally have it’s own 
drive electronics comprising a digital signal processor, a 
microcontroller, a random access memory, and a system 
controller. The host computer communicates with the com- 
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pact disk drive controller via an IDE data bus and receives 
digital information from the compact disk via the IDE data 
bus. The compact disk drive controller is comprised of a host 
interface, connecting the host computer via the IDE data bus 
with the compact disk drive controller, in order to receive 
data addresses and commands from the host computer and 
transmit digital information to the host computer. A path for 
communicating data addresses and commands from the host 
interface to the microcontroller of the drive electronics is 
employed and a digital signal processor (DSP) interface 
connecting the host interface and the digital signal processor 
of the drive electronics, receives digital information from the 
compact disk and transmits the digital information to said 
host interface. 

The digital signal processor interface of the compact disk 
drive controller (CDDC) further comprises a descrambler to 
descramble and assemble the digital information received 
from said digital signal processor and store said digital 
information into said random access memory. 

The digital signal processor interface of the CDDC further 
comprises an error correction code circuit to perform error 
correction on said digital information. That error correction 
circuit could employ Reed-Solomon codes. 

The digital signal processor interface of the CDDC further 
comprises a cyclic redundancy checker for detecting errors 
in the digital information after correction of the digital 
information by the error correction code circuit. 

The host interface of the CDDC may receive data 
addresses and commands from the host computer via an ISA 
data bus and may communicate digital information to the 
host computer via the ISA bus. 

The host interface of the CDDC further comprises a 
command FIFO to transfer commands from the host com- 
puter to the system controller of the drive electronics of the 
compact disk drive. 

The host interface of the CDDC further comprises a 
configuration register via which the host computer instructs 
the compact disk drive controller to present the digital 
information onto one of the ISA and IDE data buses in a data 
format selected from a group including 16-bit DMA, 8-bit 
DMA, 16-bit PIO, and an 8-bit PIO format. 


A BRIEF DESCRIPTION OF THE DRAWINGS 


FIG. 1 is a block diagram of a CD drive configuration of 
the prior art with the IDE/ATA CD drive controller of the 
present invention added thereto. 

FIG. 2 is a block diagram of an implementation of the 
present invention. 

FIGS. 3a—c are a pin diagram and accompanying pin-out 
assignments for an implementation of the present invention. 

FIG. 4 is a pin description of the system controller 
interface of an implementation of this invention. 

FIG. 5a is a pin description of the host interface of an 
implementation of this invention. 

FIG. 5b is an address map of the host registers of an 
implementation of this invention. 

FIG. 6 is a pin description of the DSP interface of an 
implementation of this invention. 

FIG. 7 is a pin description of the subcode interface of an 
implementation of this invention. 

FIG. 8a is a pin description of the RAM interface of an 
implementation of this invention. 

FIG. 8b is a pin description for the RAM address bus of 
the RAM interface of an implementation of this invention. 
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FIG. 9 is a pin description of miscellaneous pins of an 
implementation of this invention. 

FIG. 10 is a description of the address register. 

FIG. 11 is a description of command packet register. 

FIG. 12 is a description of interface status and interface 
control registers. 

FIG. 13 and FIG. 14 are descriptions of DBCL and DBCH 
(Data Byte/Word Counter). 

FIG. 15, FIG. 16, FIG. 17 and FIG. 18 are descriptions of 
HEADO to HEAD3 (Header Registers). 

FIG. 19 is a list of DACH, DACL settings for various 
starting points. 

FIG. 20 and FIG. 21 are ECC block pointer/write address 
counters. 

FIG. 22 is a description of WAL/CTRLO (Control-0 
Register). 

FIG. 23 is a description of CTRLO DECODER OPERA- 
TION TABLE. 

FIG. 24 is a description of CTRL1 (Control-1 Register). 

FIG. 25 is a description of STATO (Status-0 Register). 

FIG. 26 is a description of STATO BLOCK SYNC STA- 
TUS TABLE. 

FIG. 27 is a description of SSTAT1 (Status-1) register. 

FIG. 28 is a description of STAT2 (Status-2) register. 

FIG. 29 is a description of STAT2 RMODE TABLE. 


FIG. 30 is a description of STAT3/RESET (Status-3) 
register. 


FIG. 31 is a description of CTRLW (Control-Write) 
register. 

FIG. 32 is a description of CRTRG (Correction Retry 
Trigger). 

FIGS. 33 through 38 are descriptions of SUBH0 to 
SUBH3 (Subheader Registers). 

FIG. 39 is a description of Subheader Byte Number Table. 

FIG. 40 is a description of VER (Version) register. 

FIG. 41 is a description of DSPSL (DSP Selection) 
register. 


FIG. 42 DSP SELECTION TABLE shows the settings for 
various DSPs. 


FIG. 43 is a description of the HCON/UACL register. 

FIG. 44 is a description of the DSPSL register. 

FIGS. 45, 46 and 47 are descriptions of the UACL, 
UACH and UACU Microcontroller-RAM Address Counter. 

FIG. 48 is a description of the RAMRD/RAMWR RAM 
Read and Write registers. 

FIG. 49 is a description of HDDIR Host data Direction 
Register. 

FIG. 50 is a list of the only values that should be written 
to HDDIR—write bits 4, 3, 2, 1 and 0, following hardware 
or firmware reset. 

FIG. 51 is a description of the HICTL Host Interface 
Control register. 

FIG. 52 is a description of SUBC2 Subcode Control-2 
register. 

FIG. 53 is a description of the DSP Subcode Clock 
TABLE. 

FIG. 54 is the STATS Status of subcode register. 

FIGS. 55 and 56 are descriptions of DBACL and DBACH 
Data Transfer Block Registers. 

FIGS. 57 and 58 are descriptions of SBKL and SBKH 
Subcode Write Block Registers. 
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FIGS. 59 and 60 are descriptions of WBKL and WBKH 
Decoder and Buffer-Write Block Counter registers. 

FIG. 61 is a description of RAMCF RAM Configuration 
Register. 

FIG. 62 is a table of RCF2, RCF1 and RCFO—bits 2, 1 
and 0—RAM Configuration. 

FIG. 63 is a description of MEMCF (Memory Layout 
Configuration) register. 

FIG. 64 is a description of MLY1 and MLY0—tits 1 and 
0—Memory Layout Configuration. 

FIG. 65 is a description of SUBCD Subcode Control 
register. 

FIG. 66 is SBSEL1 and SBSELO—bits 1 and 0—Subcode 
Format Select Table. 

FIG. 67 is a description of UMISC (Miscellaneous Micro- 
controller Control) register. 

FIGS. 69-75 are descriptions of the ATAPI Task File 
Registers (TR). 

FIG. 69 is a description of ATFEA and ATERR. 

FIG. 70 is a description of ATINT—I/O of Interrupt 
Reason TR. 

FIG. 71 is a description of ATSPA—Spare TR. 

FIG. 72 is a description of ATBLO—I/O of Byte Count 
Low TR. 

FIG. 73 is a description of ATBHI—1/O of Byte Count 
High TR. 

FIG. 74 is a description of ATDRS—1/O of Drive Select 
TR. 

FIG. 75 is a description of ATCMD—Output from Com- 
mand Register. 

FIGS. 76-83 are descriptions of the Microcontroller to 
Host Data Transfer Registers. 


DESCRIPTION OF A PREFERRED 
EMBODIMENT 


Reference is now made to FIG. 1 which is a block diagram 
of a compact disk (CD) drive configuration of the prior art 
with a CD drive controller of the present invention added 
thereto. The CD drive controller designed according to this 
invention would communicate command data, status signals 
and other data over the integrated device electronics/AT 
attachment (IDE/ATA) bus of a personal computer. This 
invention reduces the cost of a CD drive by eliminating the 
need for a host adapter card or additional ISA bus interface 
electronics. This invention also allows the CD drive to 
integrate into many personal computers without requiring 
the use of an ISA input/output bus slot. Furthermore, this 
invention will allow for a wider selection of personal 
computer peripheral cards, such as sound and boards, for use 
with a given personal computer and CD drive. The method 
of the current invention reduces this potential for 
incompatibility, and permits a broad range of selection of 
peripheral devices. 

The drive controller 10 is connected to drive electronics 
12 of a CD drive 14 and IDE/ATA bus 16 of a personal 
computer. The clock speed of the controller will be deter- 
mined by crystal oscillator 11. It will be understood that the 
compact disk 18 is not a part of the present invention but it 
is shown for clarity. The CD drive includes a spindle motor 
20 for rotating the CD and an optical head 22 for reading 
data from the CD. The drive electronics of the CD drive 
include a preamplifier 24 which sends a signal to servo 
control 26 of the CD drive for focus and tracking control. 
The servo control communicates with the spindle motor and 
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optical head to position the optical head precisely to read the 
correct information from the CD. Digital data read from the 
preamplifier goes to digital signal processor (DSP) 28 in the 
drive electronics. The DSP sends subcode information as 
well as digital data to the drive controller of this invention. 
A microcontroller 29 in the CD drive electronics also 
communicates with the DSP and servo control of the drive 
electronics, as well as with the drive controller of the present 
invention, to control the reading of information from the 
CD. A DRAM 30 is coupled with the drive controller of the 
present invention for storing and buffering data via the drive 
controller. Data can be sent to digital-to-analog convertor 
(DAC) 32 and peripheral 34 (such as a monitor) from the 
DSP or from the drive controller. 

FIG. 2 is a block diagram of an implementation of the 
drive controller 10 of the present 30 invention. The key 
functional blocks are the DSP data and subcode interfaces 36 
and 37, the buffer DRAM control 38, the error correction 
code (ECC) data corrector 40, the error detection and 
correction/cyclic redundancy checker (EDC/CRC) 42 and 
host control or interface 44. The DSP data interface 
descrambles and assembles data from the DSP 28, then 
stores the data into the RAM. The DSP subcode interface 
assembles subcode and stores P-W data into the RAM. A 
DSP address counter 58 generates an address for each block 
of data stored to the DRAM from the DSP interface. The 
error correction circuitry would first perform Reed-Solomon 
error correction on each block of data. Reed-Solomon codes 
are random single- or multiple-symbol error correcting 
codes operation on symbols which are elements of a finite 
field. All encoding, decoding, and correction computations 
are performed in the field. (See Practical Error Correction 
Design for Engineers, revised second edition, Cirrus Logic 
1991 by Neal Glover and Trent Dudley). Then, a cyclic 
redundancy check of the corrected data would be performed. 
Since each codeword contains two parity bytes the drive 
controller of this invention can correct one error in each 
codeword. These ECC and EDC-CRC circuits are com- 
monly available as hardware used in many other applica- 
tions. The host control allows the corrected data to be 
transferred from the RAM to the host Diagnostic data can be 
transferred from the host to the RAM, allowing testing of the 
ECC. EDC, host control RAM and system controller. Opera- 
tion of the drive controller is controlled by the microcon- 
troller 29, sometimes referred to as a system controller 
through an 8-bit bus. The invention can decode CD media 
according to the Sony-Philips standard for CD-ROM and 
CD-I formats. These formats divide each 2 KB data block 
into two planes, each plane containing 43 P-codewords and 
26 Q-codewords. Each codeword contains two parity bytes. 

The host computer (not shown) is connected, through the 
IDE/ATA bus 16 and associated host interface, to microcon- 
troller 29 of the drive electronics of the CD drive and the 
host control 44. The host interface provides 8/16 bit periph- 
eral input/output (PIO) and direct memory access (DMA) 
transfers of data to the host personal computer. The output 
buffers 54 of the invention can directly drive an IDE/ATA 
bus. The host interface also contains control and transfer 
status registers 56 accessible by the host. The design of the 
present invention allows the transfer of diagnostic data from 
the host to the RAM, allowing testing of the error correction 
circuitry, the host interface, the RAM itself and the system 
controller of the drive electronics. 

The DRAM controller is connected to DRAM 50. The 
DRAM controller, under the direction of the host interface, 
accomplishes the transfer of data to the host and the error 
correction operations so as to insure an uninterrupted flow of 
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data from the buffer RAM. The DRAM receives information 
from the DSP of the drive electronics via the DSP data and 
subcode logic interfaces. The DRAM also receives address 
information from the host microprocessor address counter 
60, as well as receives corrected and addressed information 
from an ECC EDC address generator 52 which is connected 
with the error correction circuit ECC and the cyclic redun- 
dancy checker EDC CRC. Additionally, the DRAM stores 
header and subheader information to the header/subheader 
register 62. 

Thus, the drive controller 10 accepts digital data from the 
CD drive’s electronics 12, particularly the microcontroller 
29 and DSP 28 in a serial stream, descrambles the data and 
assembles it into 8-bit bytes. The controller 10 then stores 
the data into the DRAM buffer 50. The error correction and 
detection operations performed by the ECC 40 and EDC 
CRC 42 on each sector of data are managed by the DRAM 
controller 35, which insures, through the direction of the 
host interface or control 44, that a sector of data is being 
corrected while the transfer of previously corrected sectors 
of data is occurring in real-time and without interrupting the 
flow of data from the drive controller 10 to the IDE bus 16. 
The flow of data is controlled by a data path controller 64. 
Therefore, the controller 10 of the present invention com- 
municates corrected command data, status signals, and other 
corrected data over the IDE bus 16 of the host computer, 
eliminating the need for a host adapter card or additional ISA 
bus interface electronics, to reduce the cost of the CD drive 
14. The invented controller 10, additionally, allows the CD 
drive 14 to integrate into many different personal computers, 
without requiring the use of an ISA input/output bus slot of 
the host computer. 


FIGS. 3a—3c are a pin diagram and accompanying pin-out 
assignments for an implementation of the present invention. 
The functions performed by this implementation will 
become clear by the following discussion. 


FIG. 4 is a pin description of the system controller 
interface of an implementation of this invention. The system 
controller is the microcontroller that controls the operation 
of the IDE CD-ROM controller. The system controller 
interface contains an 8-bit bidirectional data transfer bus and 
is compatible with most microcontrollers. 


FIG. 5a is a pin description of the host interface of an 
implementation of this invention. This invention will sup- 
port the ATAPI CD-ROM specification for an IDE CD-ROM 
interface. The drive controller can drive IDE interface signal 
lines directly. The host interface contains a 12 bytes com- 
mand packet FIFO (first in first out) and IDE registers. These 
are used to direct or command the host interface by the host 
controller and to inform the host controller as to the precise 
status of the drive electronics. The host interface block also 
contains a data FIFO register for transferring data from the 
DRAM buffer to the host and vice versa. FIG. 5b is an 
address map of the host registers of an implementation of 
this invention. The logic conventions are as follows: 
Assignal asserted, N=signal negated. 


FIG. 6 is a pin description of the DSP interface of an 
implementation of this invention. This invention is designed 
to work with various DSP chips, which are selected using the 
DSPSL register. Serial data is received from the DSP. FIG. 
7 is a pin description of the subcode interface of an imple- 
mentation of this invention. P-W subcode information pro- 
vided serially by the DSP will be stored into the data block 
of the DRAM simultaneously. This invention will support 
several different subcode interface protocols, which are 
selected using the SUBCD register. The command FIFO 
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register COMIN is used to direct the host interface by the 
host controller. 


FIG. 8a is a pin description of the RAM interface of an 
implementation of this invention. This embodiment allows 
users to use conventional 128 KB/256 KB DRAM. FIG. 8b 
is a pin description for the RAM address bus of the RAM 
interface of an implementation of this invention. Note that 
several RAM address bits are reserved for future support of 
larger RAM sizes. FIG. 9 is a pin description of miscella- 
neous pins of an implementation of this invention. 


Microcontroller Registers 


The following map and description of the registers of an 
embodiment of this invention is intended for use in designs 
supporting the following configurations: 

1. Type of RAM: 256Kx4x1 DRAM or 256Kx4x2 

DRAM 
2. Type of Host Interface: ATA (IDE) plus ATAPI 
CD-ROM 

FIG. 10 is a description of the address register. The 
internal registers are indirectly addressed. The AR register 
holds the address of the register accessed with the subse- 
quent R/W operation. The AR is read or written by the 
microcontroller if URS=0. If URS=1, the register addressed 
by the AR is read or written. 

Except for address 00h (COMIN/SBOUT), the 4 least 
significant bits (bits 0-3) of the AR are automatically 
incremented following each read or write to any register For 
example, if the AR has been set to 2Ch, the AR automati- 
cally increments according to the following sequence during 
18 consecutive reads or writes (with URS=1): 2Ch, 2Dh, 
2Eh, 2Fh, 20h, 21h, 22h, 23h, 24h, 25h, 26h, 27h, 28h, 29h, 
2Ah, 2Bh, 2Ch, 2Dh. 

Note: The AR does not automatically increment from 00h 
to 01h. Consecutive accesses to address 00h will repeatedly 
read (COMIN) or write (SBOUT). For example if the AR 
has been set to OCh, the AR automatically increments 
according to the following sequence during 7 consecutive 
reads or writes (with URS=1): O0Ch, ODh, OEh, OFh, 00h, 
00h, 00h. 

FIG. 11 is a description of command packet register. This 
register accesses the 12-byte Packet FIFO which receives 
commands or data from the host. The data transfer end 
interrupt (DTEIb) flag in the IFSTAT register is active (set 
to 0) while the 12-byte Packet FIFO is full. The command 
interrupt (CMDIb) flag in the IFSTAT register is active (set 
to 0) while one or more bytes from the host are present in the 
Packet FIFO. If an access from COMIN is attempted while 
the FIFO is empty, the value Ffh will be read. 

Normally, flag DTEIb is used for receiving 12-byte packet 
commands from the host, and flag CMDIb is used for 
receiving data from the host (which may not be 12-bytes). 
Registers ATBHI and ATBLO (addresses 34h and 35h) can 
be used to control the number of consecutive bytes of DATA 
written into the Packet FIFO by the host. However, ATBHI 
and ATBLO should not be used to control the number of 
COMMAND bytes. Command or data writes from the host 
to the data port (1F0) are stored in the Packet FIFO if control 
bit Scod in register HICTL (20h.2) is set high. Note: An 
access to the COMIN register (00h) does not increment the 
AR. 

UNUSED (O1h-write) writes to address 00h in the con- 
troller accessed the SBOUT (status byte output) register. 
However, SBOUT is not useful for ATAPI operations. 
Address 00h should not be written to. Note: An access to 
address 00h does not increment the AR. 


US 6,584,527 B2 


9 


FIG. 12 is a description of interface status and interface 
control registers. 

IFSTAT (Interface Status Register) holds the decoder and 
host interface status bits. 

CMDIb—bit 7—Command Interrupw flag is active-low 
with a logical 0 indicating an interrupt flag. “0” indicates 
that there are one or more bytes present in the Packet FIFO 
and “1” indicates that the Packet FIFO is empty. Flag 
CMDlb is used for receiving data from the host, which may 
not be 12-bytes. For receiving 12-byte packet commands, 
nag DTEIb in register IFSTAT is used instead. CMDIb is 
automatically cleared (set to 1) after the last byte in the 
Packet FIFO is read. If control bit CMDIEN in the IFCTRL 
register (01h.7) is set high, pin UINTb (the microcontroller 
interrupt) will be active-low whenever the CMDIb flag is 
active-low. 

DTEIb—bit 6—Data-Transfer-End Interrupt flag is 
active-low with a logical 0 indicating an interrupt flag. “O” 
indicates that a host read from the Data FIFO or external 
RAM, or a 12-byte host write to the Packet FIFO (Packet 
FIFO full), is complete and “1” indicates that the interrupt 
flag has been cleared. DTEIb is automatically cleared when 
the microcontroller writes to the DTACK register (07h). If 
control bit DTEIEN in the IFCTRL register (01h.6) is set 
high, pin UINTb (the microcontroller interrupt) will be 
active-low whenever the DTEIb flag is active-low. 

DECIb—bit 5—Decoder Interrupt flag is active-low with 
a logical 0 indicating an interrupt flag. “0” indicates that the 
decoder has finished processing a block and “1” indicates 
that the interrupt nag has been cleared. When DECIb 
changes to active-low, the header registers (HEADO-3), 
ECC block pointer registers (PTL, PTH), and status registers 
(STATO-3) are ready to be read. If the ECC or EDC is 
enabled, DECIb changes to active-low at the completion of 
the EDC phase. If the ECC and EDC are disabled (write- 
only or disk-monitor operation), DECIb changes to active- 
low after the header registers (HEADO0-3) are ready. DECIb 
is automatically cleared (to 1) when the microcontroller 
reads the STAT3 register (OFh). 

X—bit 4 is undefined, and may return a 0 or 1. 

DTBSYb—bit 3—Data Transfer Busy flag is active-low 
with a logical 0 indicating a busy flag. “O” indicates that a 
data-transfer is in process and “1” indicates that no data- 
transfer in process. DTBSYb changes to active-low when 
the microcontroller writes to the data transfer trigger 
(DTTRG). DTBSYb is automatically cleared (to 1) when the 
host BEGINS to read the last byte to be transferred from the 
Data FIFO or external RAM. 

X—bit 2 is undefined, and may return a 0 or 1. SBOUT 
is not useful for ATAPI operation. 

DTENb—bit 1—Date Enable is active-low with a logical 
0. “0” indicates that a data-transfer is in process and “1” 
indicates that no data-transfer is in process. After DTTRG is 
set, DTENb changes to active-low when the Data FIFO is 
ready to be read by the host. DTENb is automatically cleared 
(to 1) after the host reads the last byte to be transferred from 
the Data FIFO or external RAM. 

X—bit 0 is undefined, and may return a 0 or 1. SBOUT 
is not useful for ATAPI operation. 

IFCTRL (Interface Control Register) provides control of 
the microcontroller interrupt and host interface. 

CMDIEN—bit 7—Command Interrupt Enable “1” allows 
pin UINTb (the microcontroller interrupt pin) to become 
active-low whenever the CMDIb flag in register IFSTAT is 
active-low. “0” inhibits the CMDIb flag from activating pin 
UINTb. CMDIEN controls the operation of pin UINTb. 
However, CMDIEN does not clear the interrupt request or 
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control the CMDIb flag. CMDIEN is cleared to 0 by 
hardware reset or firmware reset. 

DTEIEN—bit 6—Data-Transfer-End Interrupt Enable 
“1” allows pin UINTb (the microcontroller interrupt-pin) to 
become active-low whenever the DTEIb flag in register 
IFSTAT is active-low. “0” inhibits the DTEIb flag from 
activating pin UINTb. DTEIEN controls the operation of pin 
UINTb. However, DTEIEN does not clear the interrupt 
request or control the DTEIb flag. DTEIEN is cleared to 0 
by hardware reset or firmware reset. 

DECIEN—bit 5—Decoder Interrupt Enable “1” allows 
pin UINTb (the microcontroller interrupt pin) to become 
active-low whenever the DECIb flag in register IFSTAT is 
active-low. “0” inhibits the DECIb flag from activating pin 
UINTb. DECIEN controls the operation of pin UINTb. 
However, DECIEN does not clear the interrupt request or 
control the DECIb flag. DECIEN is cleared to 0 by hardware 
reset or firmware reset. 

DOUTEN—it 1—Data Output Enable “1” enables host 
data reads from the Data FIFO or external RAM, or host 
writes to the Packet FIFO. “0” inhibits data transfers to the 
Data FIFO, external RAM, or Packet FIFO. Clearing 
DOUTEN (to 0) aborts data transfers to the FIFOs or 
external RAM. DOUTEN is cleared to 0 by hardware reset 
or firmware reset. 

Unused Bits—bits 4, 3, 2, and 0 should only be set to 0. 

FIG. 13 and FIG. 14 are descriptions of DBCL and DBCH 
(Data Byte/Word Counter) that form a 12-bit counter that 
controls or monitors the number of bytes or words trans- 
ferred from the Data FIFO or external RAM to the Host. For 
16-bit transfers, the number of WORDS minus one should 
be loaded into this counter. For 8-bit transfers, the number 
of BYTES minus one should be loaded. DBCH should 
always be written after DBCL is written, and zero should be 
written into bits 7-4 of DBCH. During the data transfer, the 
counter is decremented by one each time the host reads a 
word or byte. When reading DBCH, bits 7-4 each indicate 
the status of the data-transfer-end interrupt (DTED, and have 
the same function (but opposite polarity) as the DTEIb flag 
in register IFSTAT. DBCL and DBCH are undefined fol- 
lowing hardware reset or firmware reset. 

FIG. 15, FIG. 16, FIG. 17 and FIG. 18 are descriptions of 
HEADO to HEAD3 (Header Registers). Normally, these 
registers provide the header of each CD-ROM block, and are 
used to find the starting block during a disk seek. If control 
bit DECEN in register CTRLO (OAh.7) is enabled, the first 
four bytes (bytes 12-15) following each data sync are 
automatically stored in the header registers (HEADO-3). 
During disk-monitor operation (see the description of reg- 
ister CTRLO), uncorrected header bytes are taken directly 
from incoming serial data. If the incoming serial data is 
buffered, header bytes are taken from the buffer RAM, and 
are corrected if mode 1 is selected and ECC is enabled. In 
either case, HEADO-3 should be read soon after the decoder 
interrupt occurs (bit DECIb in register IFSTAT becomes 0). 
HEAD0-3 remains valid until the next sync occurs (see the 
description of register STAT3 for checking the valid time 
period). Generation of checkbytes during the authoring of 
CD-ROM disks includes ECC coverage of the header bytes 
for mode 1 blocks, but not for mode 2 blocks. Therefore if 
ECC is enabled, the header bytes are not valid unless the 
proper mode is selected using control bit MODRQ in 
register CTRL1 (OBh.3). Operation of a mode 2 disk with 
mode 1 ECC causes the header bytes to be erased. By setting 
control bit SHDREN in register CTRL1 high, HEADO-3 
can be used to provide subheader bytes instead of header 
bytes. However, it is more convenient to use registers 
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SUBHO0-3 (14h-17h), which are not controlled by bit 
SHDREN, for this purpose. See the description of SUBH0-3 
for subheader information. Subheaders in HEADO-3 follow 
the same format and operation as subheaders in SUBHO-3. 
HEADO-3 are undefined following hardware reset or firm- 
ware reset. 

FIG. 19 is a list of DACH, DACL settings for various 
starting points. DACL and DACH are Data Address 
Counters. DACL and DACH form a 16-bit counter that 
controls the buffer RAM address for transfers to the host. 
The microcontroller writes the starting address that corre- 
sponds to the required starting point in the CD-ROM block. 
After the starting address is set and register DTTRG is 
triggered, DACL and DACH are incremented automatically 
each time a byte or word is read by the host. The first byte 
of User Data is located at address 00h. DACH should always 
be written after DACL is written. For proper addressing, the 
mode of the CD-ROM block should be selected using 
control bit MODRQ in register CTRL1 (OBh.3). DACL and 
DACH control the RAM address relative to the beginning of 
the block. The block number should also be specified, using 
data block registers DBACL and DBACH (24h and 25h). 
DACL and DACH are undefined following hardware reset 
or firmware reset. 

DTTRG (Data Transfer Trigger) triggers the host transfer 
logic and prepares the Data FIFO, causing flag DTBSYb in 
register IFSTAT (01h.3) to become active-low. Before set- 
ting or triggering any data transfer registers, control bit 
DOUTEN in register IFCTRL (01h.504 1) should be 
enabled. In the case of a host data read from the buffer RAM, 
triggering the transfer logic automatically fills the FIFO with 
data from the RAM. The count, RAM starting address, and 
block number should be set using registers DBCL, DBCH, 
DACL, DACH, DBACL, and DBACH (02h, 03h, 04h, 05h, 
24h, and 25h) before triggering DTRG. Flag DTENb in 
register IFSTAT (01h.1) becomes active-low when the FIFO 
first becomes ready. The microcontroller can also load 
registers UDTAOQ-UDTA7, allowing host data reads (up to 
8-bytes) from the microcontroller without using the buffer 
RAM. In this case the byte count, microcontroller data 
enable, and data bytes should be set using registers DBCL, 
DBCH, HDDIR, and UDTA0-7 (02h, 03h, 1Fh.6, and 
40h-47h) before triggering DTTRG. After triggering 
DTTRG, trigger bit UDTRG in register HDDIR (1Fh.7) 
should be toggled to 1 followed by 0. For this type of 
transfer, flag DTENb in register IFSTAT (01h.1) has no 
meaning. Trigger DTTRG is not used for host writes to the 
Packet FIFO. 

DTACK (Data Transfer Acknowledge) clears flag DTEIb 
to 1 in register IFSTAT (01h.6) and also clears the corre- 
sponding microcontroller interrupt (if enabled), terminating 
the data transfer sequence. 

FIG. 19 and FIG. 20 are ECC block pointer/write address 
counters. PTL and PTH form a pointer used by the ECC 
logic, and contain the 12 least significant address bits of the 
first header byte of the CD-ROM block that is being cor- 
rected. Due to the DRAM page organization of one embodi- 
ment of the controller, the value of PTH,PTL will always be 
00,00h, making it unnecessary to read or write PTL or PTH. 
The starting location of each block is controlled by write 
block counter registers WBKL and WBKH (28h and 29h). 
Error correction is processed on the block before that 
indicated in the write block counter (WBKH,WBKL-1). The 
controller organizes the DRAM into 2048-byte pages, 
allowing PTL and PTH to remain unchanged. PTL and PTH 
are undefined following hardware reset or firmware reset. 

WAL and WAH (Write Address Counter) form a 16-bit 
counter used by the write buffering logic. At the end of each 
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data sync, WAH,WAL are automatically set to 00,00h. 
Following each word (two bytes) of write buffering into the 
external RAM, WAL and WAH are automatically incre- 
mented by two. Due to the DRAM page organization of the 
controller, WAL and WAH control the write location within 
each CD-ROM block, and are always set to 00,00h after 
each data sync. The starting location of each block is 
controlled by write block counter registers WBKL and 
WBKH (28h and 29h). It is not necessary to read or write 
WAL or WAH, except for debugging purposes. Because 
WAL and WAH are automatically incremented whenever 
control bits DECEN and WRRQ are enabled in register 
CTRLO (OAh.7 and OAh.2), WRRQ should be disabled 
before reading the write address counter. WAH,WAL are 
cleared to 00,00h by hardware reset or firmware reset. 

FIG. 22 is a description of WAL/CTRLO (Control-0 
Register). This register provides control of the ECC and 
write buffering logic. 

DECEN—bit 7—Decoder Enable “1” enables the decod- 
ing functions, allowing control bits EOLRQ, AUTORQ, 
WRRQ, QRQ, and PRQ to control the ECC and write 
buffering logic. “0” disables the decoding functions, over- 
riding control bits E0LRQ, AUTORQ, WRRQ, QRQ, and 
PRQ. Changes to DECEN control the CD-ROM blocks 
following the next data sync. DECEN is cleared to 0 by 
hardware reset or firmware reset. 

E01RQ—bit 5—Error Detect and Correct Request “1” 
enables the error correction and detection (ECC and EDC) 
logic to process the following CD-ROM blocks, according 
to the settings of QRQ and PRQ. “0” disables the ECC and 
EDC logic. Changes to E01RQ control the CAROM blocks 
following the next data sync. If both QRQ and PRQ are 
enabled, the ECC/EDC sequence is Q-codewords, 
P-codewords, EDC-codeword. If QRQ is enabled but PRQ 
is disabled, the sequence is Q-codeword, EDC-codeword. If 
QRQ is disabled but PRQ is enabled, the sequence is 
P-codeword, EDC-codeword. If both QRQ and PRQ are 
disabled, only the EDC-codeword is checked. Normally, 
QROQ and PRQ are enabled whenever EO1RQ is enabled in 
order to provide maximum correction capability. E01RQ is 
cleared to 0 by hardware reset or firmware reset. 

AUTORQ—bit 4—Automatic Correction Request “1” 
enables automatic error correction for mode 2 CD-ROM 
blocks, according to the setting of the FORM bit in the 
Subheader byte of each block. “0” disables automatic error 
correction for mode 2 CD-ROM blocks. In this case, error 
correction for mode 2 blocks is controlled by control bit 
FORMRQ in register CTRL1 (OBh.2). Changes to 
AUTORQ control the CD-ROM blocks following the next 
data sync. AUTORQ does not control error correction in 
mode 1. AUTORQ is cleared to 0 by hardware reset or 
firmware reset. 

WRROQ—bit 2—Write Buffer Request “1” enables writes 
of incoming serial data to the external buffer RAM. auto- 
matically incremented when writes are enabled. “0” disables 
writes of incoming serial data to the external buffer DRAM. 

If control bit SWEN is enabled in register CTRLW 
(10h.6), changes to WRRQ control writes following the next 
data sync. If SWEN is disabled, changes to WRRQ control 
writes immediately. Both WRRQ and SWEN are cleared to 
0 by hardware reset or firmware reset. 

QRQ—bit 1—Q-codeword Correction Request “1” 
enables error correction of Q-codewords, allowing one error 
to be located and corrected within each Q-codeword. “0” 
disables error correction of Q-codewords. Changes to QROQ 
control the CD-ROM blocks following the next data sync. 
QRQ is cleared to 0 by hardware reset or firmware reset. 
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PRQ—bit 0—P-codeword Correction Request “1” 
enables error correction of P-codewords, allowing one error 
to be located and corrected within each P-codeword. “0” 
disables error correction of P-codewords. Changes to PRQ 
control the CD-ROM blocks following the next data sync. 
PRQ is cleared to 0 by hardware reset or firmware reset. 

FIG. 23 is a description of CTRLO DECODER OPERA- 
TION TABLE. NOTE: For repeated correction, see the 
description of register CRTRG (11h). For buffered-disk- 
monitor, see the description of control bit ROWEN in 
register CTRLW (10h.7). 

FIG. 24 is a description of CTRL1 (Control-1 Register). 
This register provides control of the ECC and data syne 
logic. 

SYIEN—bit 7—Sync Insertion Enable “1” enables sync 
insertion, allowing the internal syne counter to provide 
timing if the block sync pattern in the incoming serial data 
contains errors. “0” disables sync insertion. By enabling 
both SYIEN and SYDEN, the internal sync counter can 
automatically provide timing if the sync pattern contains 
errors, and also re-synchronize whenever a new sync pattern 
is detected. SYIEN is cleared to 0 by hardware reset or 
firmware reset. 

SYDEN—bit 6—Sync Detection Enable “1” enables syne 
detection, allowing the internal syne counter to 
re-synchronize whenever a block sync pattern is detected in 
the incoming serial data. “0” disables sync detection. 
SYDEN is cleared to 0 by hardware reset or firmware reset. 

DSCREN—bit 5—Descrambler Enable “1” enables the 
CD-ROM data descrambler. “0” disables the CD-ROM data 
descrambler. Disabling the descrambler is useful for reading 
uncompressed (Red Book) audio, or for debugging. Changes 
to DSCREN control the descrambler immediately. DSCREN 
is cleared to 0 by hardware reset or firmware reset. 

COWREN—bit 4—Correction Write Enable “1” enables 
bytes corrected by the ECC logic to be written to the external 
RAM. “0” disables bytes corrected by the ECC logic to be 
written to the RAM. By disabling COWREN, flags CRCOK 
and CBLK in registers STATO (OCh.7) and STAT3 (OFh.5) 
can be used to determine disk error rates. Changes to 
COWREN control the CDROM blocks following the next 
data sync. COWREN is cleared to 0 by hardware reset or 
firmware reset. 

MODRQ—bit 3—Mode Request “1” sets the error cor- 
rection mode used by the ECC logic to mode 2. “0” sets the 
error correction mode used by the ECC logic to mode 1. 
After determining the mode from the incoming serial data, 
control bit MODRQ must be set by the microcontroller. The 
raw mode data from the headers of the incoming serial data 
should be read from bits RMOD3-0 in register STAT2 
(OEh.7-4). If MODRQ is not set properly, the ECC logic 
will mis-correct. Note that operation of a mode 2 disk with 
mode 1 correction causes the header bytes to be erased. 
MODRQ is cleared to 0 by hardware reset or firmware reset. 
Generation of checkbytes during the authoring of CD-ROM 
disks includes ECC coverage of the header bytes for mode 
1 blocks, but not for mode 2 blocks. Consequently, the mode 
byte in a mode 2 disk is not corrected. Mode changes are 
separated by pre-gap and post-gap blocks and track num- 
bers. Changes to MODRQ control the CD-ROM blocks 
following the next data sync. MODRQ is cleared to 0 by 
hardware reset or firmware reset. 

FORMRQ—bit 2—Form Request “1” sets the form to 2, 
disabling the mode 2 ECC logic (but EDC is enabled). “0” 
sets the form to 1, enabling the mode 2 ECC logic. If control 
bit AUTORQ is enabled in register CTLO (OAh.4), the 
setting of FORMRQ is not used by the ECC logic. 
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FORMRQ is not used by the ECC logic if mode 1 is selected 
(control bit MODRQ set to 0 in register CTRLO). Changes 
to FORMRQ control the CD-ROM blocks following the 
next data sync. FORMRQ is cleared to 0 by hardware reset 
or firmware reset. 

MBCKRQ—bit 1—Mode Byte Check Request “1” 
enables checking of the mode byte. “0” disables checking of 
the mode byte. While checking of the mode byte is enabled, 
if the mode in the header of the incoming serial data does not 
match that selected by control bit MODRQ, ECC is disabled 
for the block and the NOCOR flag is set in register STATO 
(OCh.5). Changes to MBCKRQ control the CD-ROM blocks 
following the next data sync. MBCKRQ is cleared to 0 by 
hardware reset or firmware reset. 

SHDREN—bit 0—Subheader Read Enable “1” selects 
subheader bytes to be provided by registers HEADO-3 
(04h-O07h). “0” selects header bytes to be provided by 
registers HEADO-3. By setting SHDREN high, HEAD0-3 
can be used to provide subheader bytes instead of header 
bytes. However, it is more convenient to read the subheader 
from registers SUBHO-3 (14h-17h), which are not con- 
trolled by SHDREN. Changes to SHDREN control reads of 
HEAD0-3 immediately. SHDREN is cleared to 0 by hard- 
ware reset or firmware reset. 

FIG. 25 is a description of STATO (Status-0 Register). 
This register provides status of the ECC, write buffering, and 
data sync logic. 

CRCOK—bit 7—Cyclic Redundancy Check OK. Flag 
CRCOK can become active-high only if the error detection 
(EDC) logic is enabled. This occurs automatically if correc- 
tion or write-only decoder operations are selected (see the 
CTRLO Operation Table) and “1” indicates that the cyclic 
redundancy check passed during the last ECC/EDC 
sequence. “OQ” indicates that the cyclic redundancy check 
failed during the last ECC/EDC sequence. Flag CRCOK 
becomes valid when flag DECIb in register IFSTAT (01h.5) 
changes to active-low, and remains valid until the next block 
sync. See the description of flag VALSTb in register STAT3 
(OFh.7) to determine timing of the next sync. CRCOK is 
cleared to 0 by hardware reset or firmware reset. 

ILSYNC—bit 6—TIllegal Sync flag can become active- 
high only if syne detection is enabled by control bit SYDEN 
in register CTRL1 (OBh.6). In this case, occurrence of illegal 
sync re-synchronizes the internal syne counter. “1” indicates 
that a sync pattern was detected earlier than expected (less 
than 2352 bytes after the last detected or inserted sync). “0” 
indicates that no early sync pattern was detected. Flag 
ILSYNC becomes valid when flag DECIb in register 
IFSTAT (01h.5) changes to active-low, and remains valid 
until the next block sync. ILSYNC is cleared to 0 by 
hardware reset or firmware reset. 

NOSYNC—bit 5—No Sync flag can become active-high 
only if sync insertion is enabled by control bit SYIEN in 
register CTRL1 (OBh.7). In this case, the internal sync 
counter will provide timing when the sync pattern is missing 
or has errors. “1” indicates that a sync pattern was not 
detected when expected (expected sync to occur 2352 bytes 
after the last detected or inserted sync). “O” indicates that a 
sync pattern was detected when expected. Flag NOSYNC 
becomes valid when flag DECIb in register IFSTAT (01h.5) 
changes to active-low, and remains valid until the next block 
sync. NOSYNC is cleared to 0 by hardware reset or firm- 
ware reset. 

LBLK—bit 4—Long Block flag can become active-high 
only if sync insertion is disabled by control bit SYTEN in 
register CTRL1 (OBh.7). In this case, the internal syne 
counter will not provide timing when the sync pattern is 
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missing or has errors. However, only 2352 bytes of incom- 
ing serial data will be written to the external RAM. “1” 
indicates that a sync pattern was not detected when expected 
(expected sync to occur 2352 bytes after the last detected 
sync). “O” indicates that a syne pattern was detected when 
expected. Flag LBLK becomes valid when flag DECIb in 
register IFSTAT (01h.5) changes to active-low, and remains 
valid until the next block sync. LBLK is cleared to 0 by 
hardware reset or firmware reset. 

\WSHORT—bit 3—Word Short “1” indicates that the 
incoming serial data rate exceeds the capability of the write 
buffering logic. “0” indicates that the incoming serial data 
rate was OK. The WSHORT error flag becomes valid 
immediately after the excessive rate is detected. This error is 
usually caused by hardware problems, and must be corrected 
for proper controller operation. WSHORT is cleared to 0 by 
hardware reset or firmware reset. 

SBLK—bit 2—Short Block flag can become active-high 
only if sync detection is disabled by control bit SYDEN in 
register CTRL1 (OBh.6). In this case, occurrence of illegal 
sync will not re-synchronize the internal sync counter. “1” 
indicates that a sync pattern was detected earlier than 
expected (less than 2352 bytes after the last inserted sync). 
“0” indicates that no early sync pattern was detected. Flag 
SBLK becomes valid when flag DECIb in register IFSTAT 
(O1h.5) changes to active-low, and remains valid until the 
next block sync. SBLK is cleared to 0 by hardware reset or 
firmware reset. 

UCEBLK—bit 0—Uncorrectable Errors in Block flag can 
become active-high only if the error correction (ECC) logic 
is enabled (Q-P, Q, or P-correction decoder operation 
selected). “1” indicates that one or more error bytes could 
not be corrected during the last ECC sequence. “0” indicates 
that no error bytes remained after the last ECC sequence. 
Flag UCEBLK becomes valid when flag DECIb in register 
IFSTAT (01h.5) changes to active-low, and remains valid 
until the next block sync. UCEBLK is cleared to 0 by 
hardware reset or firmware reset. 

FIG. 26 is a description of STATO BLOCK SYNC STA- 
TUS TABLE. 

FIG. 27 is a description of SSTAT1 (Status-1) register. 
This register provides erasure flags for the header and 
subheader bytes of the CD-ROM block. The erasure flags 
are provided through input pin C2PO. 

HDERA—bit 4—Header Erasure “1” indicates that the 
erasure flag was set for one or more header bytes. “0” 
indicates that no erasure flags were set for the header bytes. 

SHDERA—bit 0—Subheader Erasure “1” indicates that 
the erasure flag was set for both bytes in one or more 
subheader byte-pairs. “0” indicates that no erasure flags 
were set for both bytes in the subheader byte-pairs. During 
disk-monitor operation (see the description of register 
CTRLO), erasures are read directly from incoming C2PO 
flags. If the incoming serial data (from pin DSTATA) is 
buffered, the incoming C2PO flags are held and become 
available in STAT1 one block later, matching the one block 
delay of the buffered header and subheaders. In either case, 
HDERA and SHDERA become valid when flag DECIb in 
register IFSTAT (01h.5) changes to active-low, and remain 
valid until the next block sync. 

FIG. 28 is a description of STAT2 (Status-2) register. This 
register provides mode and form information of the 
CD-ROM block. 

FIG. 29 is a description of STAT2 RMODE TABLE. 
RMOD3-RMOD0—bits 7-4—Raw Mode provide mode 
information from the incoming serial data, during both 
buffer RAM and disk-monitor operation. Because 
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RMOD3-RMODO cannot be changed by the ECC logic, 
they should be used for determining the mode of the 
CD-ROM block, according to the figure. N can be any 
number between 1 and 1Fh. RMOD3-RMODO0 become 
valid when flag DECIb in register IFSTAT (01h.5) changes 
to active-low, and remain valid until the next block sync. 
RMOD3-RMODO are cleared to 0 by hardware reset or 
firmware reset. 

MODE—bit 3—Selected Mode flag provides the value of 
bit MODRQ in register CTRL1 (OBh.3). “1” indicates that 
bit MODRQ is set high (mode-2 selected). “0” indicates that 
bit MODRQ is set low (mode-1 selected). Flag MODE 
becomes valid when flag DECIb in register IFSTAT (01h.5) 
changes to active-low, and remains valid until the next block 
sync. Flag MODE is cleared to 0 by hardware reset or 
firmware reset. 

NOCOR—bit 2—No Correction flag indicates whether 
error correction was performed NOCOR is valid only if 
control bit E01RQ, and QRQ or PRQ, are enabled in register 
CTRLO (OAh.5, 0Ah.1, OAh.0). “1” indicates that the last 
ECC/EDC sequence was aborted. “0” indicates that the last 
ECC/EDC sequence completed. The ECC/EDC sequence is 
aborted, and flag NOCOR set high, for the following rea- 
sons: Mode mismatch or erasure detected while control bit 
MBCKRQ is enabled in register CTRL1 (OBh.1): A mode 
mismatch occurs if the mode in the header of the incoming 
serial data does not match that selected by control bit 
MODRQ in register CTRL1 (OBh.3). A mode erasure occurs 
if the incoming C2PO flag is set for the fourth header byte, 
indicating unreliable mode data. Form 2 enabled while ECC 
logic is set to mode 2: Form 2 blocks cannot be corrected. 
Form 2 can be enabled by control bit FORMRQ in register 
CTRL1 (OBh.2), or by the FORM bit in the Subheader byte 
if control bit AUTORQ is enabled in register CTRLO 
(O0Ah.4). FORM bit erasures while ECC logic is set to mode 
2 and AUTORQ is enabled: A form bit erasure is detected if 
the incoming C2PO flags are set for both FORM bits in the 
Subheader bytes. Illegal sync occurs while control bit 
SYDEN is enabled in register CTRL1 (0OBh.6), indicating 
that a syne pattern was detected earlier than expected. 
Control bit COWREN set low in register CTRL1 (OBh.4). 
Flag NOCOR becomes valid when flag DECIb in register 
IFSTAT (01h.5) changes to active-low, and remains valid 
until the next block sync. Flag NOCOR is cleared to 0 by 
hardware reset or firmware reset. 

RFORM1—tit 1—Raw Form Erasure “1” indicates that 
a form bit erasure was detected (a form bit erasure is 
detected if the incoming C2PO flags are set for both FORM 
bits in the Subheader bytes. “O” indicates that a form bit 
erasure was not detected. RFORMI1 becomes valid when 
flag DECIb in register IFSTAT (01h.5) changes to active- 
low, and remains valid until the next block sync. RFORM1 
is cleared to 0 by hardware reset or firmware reset. 

RFORM0—bit 0—Raw Form Bit “1” indicates that the 
FORM bit was high in the Subheader bytes of the incoming 
serial data. “O” indicates that the FORM bit was low in the 
Subheader bytes of the incoming serial data. RFORMO 
becomes valid when flag DECIb in register IFSTAT (01h.5) 
changes to active-low, and remains valid until the next block 
sync. RFORM60 is cleared to 0 by hardware reset or firmware 
reset. 

UNUSED (0Eh-write) SBOUT is not useful for ATAPI. 
Address OEh should not be written to. 

FIG. 30 is a description of STAT3/RESET (Status-3) 
register. This register provides status of the ECC logic. 
Reading STAT3 clears flag DECIb to 1 in register IFSTAT 
(01h.6), and clears any active decoder interrupt. 
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VALSTb—bit 7—Valid Status flag indicates the valid 
period during which the following header, pointer, and status 
registers can be read by the microcontroller: HEADO-3 
(04h-07h), PTL and PTH (08h—09h), STATO—3 (OCh-OFh), 
SUBHO0-3 (14h-17h), and WBKL and WBKH (28h and 
29h). “1” indicates that the header, pointer, and status 
registers contain valid data, and are ready to be read. “0” 
indicates that the header, pointer, and status registers are not 
valid. Flag VALSTb becomes active-low when flag DECIb 
(decoder interrupt) in register IFSTAT (01h.5) changes to 
active-low, and returns?high when the next block sync 
occurs (detected or inserted). Reading STAT3 does not 
change VALSTb. VALSTb is cleared to 1 by hardware reset 
or firmware reset. 

CBLK—bit 5—Corrected Block flag is valid only if the 
error correction (ECC) logic is enabled (Q-P, Q, or 
P-correction decoder operation selected). “1” indicates that 
one or more error bytes were corrected during the last ECC 
sequence. “0” indicates that no bytes were corrected during 
the last ECC sequence. Flag CBLK becomes valid when flag 
DEClIb in register IFSTAT (01h.5) changes to active-low, 
and remains valid until the next block sync. CBLK is cleared 
to O by hardware reset, firmware reset, or by disabling 
WRRQ in register CTRLO (OAh.2). 

RESET (Firmware Reset) activates firmware reset. Firm- 
ware reset clears most of the controller logic. However, to 
avoid disturbing important logic, firmware reset does not 
clear certain functions. The following list shows the differ- 
ences between hardware reset (which clears all of the 
controller functions) and firmware reset. Functions NOT 
cleared by firmware reset: Clock stop logic controlled by 
input pin CLKSTP, register XTAL (1Ah) and output pin 
MCK, register DSPSL (1Bh), flag CS13 of register HDDIR 
(1Fh.6), register HICTL, register SUBC2 (21h), register 
RAMCE (2Ah), register MEMCF (2Bh), register SUBCD 
(2Ch), register UMISC (2Eh), register RSSTAT flags SRST, 
CMD, DIAGCMD, PARINT, RST, URST, and HRST 
(2Fh.7-5,3—-0), R/W bit DRV in register ATDRS (36h) and 
in the ATAPI Drive Select Register, and control bits SRST 
and nIEN in the ATAPI Device Control Register. Flag URST 
of register RSSTAT (2Fh.1) is set by firmware reset (see 
description of register RSSTAT). 

FIG. 31 is a description of CTRLW (Control-Write) 
register. This register provides control of the write buffering 
logic. CTRLW bits 7, 3, 2, 1 and 0 should always be cleared 
to 0. 

SWEN—bit 6—Synchronized Write Enable “1” enables 
synchronized write enable, causing changes by control bit 
WRRQ (0Ah.2) to be delayed until the end of the next block 
sync. “OQ” disables synchronized write enable. Selecting 
synchronized write enable causes the writing of incoming 
serial data to the buffer RAM to start or stop at the end of 
the next block sync. This prevents the writing of partial 
blocks into the RAM. SWEN should be changed only during 
decoder initialization. Write enable and disable is still con- 
trolled by bit WRRQ in register CTRLO (OAh.2). SWEN 
synchronizes changes in WRRQ to the end of sync, instead 
of randomly. SWEN is cleared to 0 by hardware reset or 
firmware reset. 

SDSS—bit 5—Subcode-DSP Sync Synchronization “1” 
enables subcode-DSP sync synchronization, causing audio 
write enables by control bit WRRQ (OAh.2) to be delayed 
until the first left-channel lower-byte following the end of 
the subcode block. “0” disables subcode-DSP sync synchro- 
nization. Selecting Subcode-DSP Syne Synchronization 
causes the writing of incoming serial audio (red book) to the 
buffer RAM to start at the first left-channel lower-byte 
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following the end of the subcode block. This prevents 
separate decoder and subcode interrupts from occurring. 
SDSS should be changed only during decoder initialization. 
Write enable and disable is still controlled by bit WRRQ in 
register CTRLO (OAh.2). SDSS synchronizes changes in 
WRRQ to the subcode block, instead of randomly. SDSS is 
cleared to 0 by hardware reset or firmware reset. 

DCLKE—bit 4—DSP Clock Enable “1” enables the 
incoming clock from the DSP. “0” disables the incoming 
clock from the DSP. DCLKE should be set high whenever 
DECEN in register CTRLO is set high. 

FIG. 32 is a description of CRTRG (Correction Retry 
Trigger) Writing 00h or 01h to register CRTRG triggers an 
error-correction retry. 

CRTRL—bit O0—Correction Retry Register Load “1” 
loads any updated EOIRQ, QRQ, or PRQ values that have 
been written to register CTRLO (0Ah.5,1,0) into the ECC 
sequencer, allowing the correction sequence to be changed. 
“0” does not load updated E01RQ, QRQ, or PRQ values into 
the ECC sequencer. Instead, the sequence of the last cor- 
rection try is repeated. 

FIGS. 33 through 38 are descriptions of SUBHO to 
SUBH3 (Subheader Registers). These registers provide the 
subheader of each CD-ROM block, and operate similarly to 
header registers HEADO-3. If control bit DECEN in register 
CTRLO (0Ah.7) is enabled, data from the four pairs of bytes 
following each header (bytes 16—23) is automatically stored 
in the subheader registers (SUBHO-3). Bytes 16-23 are 
stored regardless of the setting of control bit MODRQ in 
register CTRL1 (OBh.3), but the bytes contain subheader 
data only if mode 2 is selected (MODRQ=1). During disk- 
monitor operation (see the description of register CTRLO), 
uncorrected subheader bytes are taken directly from incom- 
ing serial data. If the incoming serial data is buffered, 
subheader bytes are taken from the buffer RAM, and are 
corrected if form 1 (mode 2) is selected and ECC is enabled. 
In either case, SUBHO-3 should be read soon after the 
decoder interrupt occurs (bit DECIb in register IFSTAT 
becomes 0). SUBHO-3 remains valid until the next sync 
occurs (see the description of register STAT3 for checking 
the valid time period). The following figure shows the 
relationship between erasure flags and the byte numbers that 
are stored in SUBHO-3 (erasure flags are provided through 
input pin C2PO. 

FIG. 39 is a description of Subheader Byte Number Table. 
SUBHO0-3 are undefined following hardware reset or firm- 
ware reset. 

FIG. 40 is a description of VER (Version) register. VER 
contains the version identification of the device. This reg- 
ister permits expansion and increased performance capabili- 
ties for future versions of the controller. VER is not changed 
by hardware reset or firmware reset. 

XTAL (Xtal) register provides control of the crystal 
frequency dividers. 

MCK1—bit 3—Pin MCK Ix “1” sets the clock output at 
pin MCK to the crystal frequency (no divider). “0” sets the 
clock output at pin MCK to ¥% crystal frequency. MCK1 is 
cleared to 0 by hardware reset, but is not changed by 
firmware reset. 

XTALD2—bit O0—Crystal Divided by 2 “1” sets the 
internal controller clock to % crystal frequency. “0” sets the 
internal clock to the crystal frequency (no divider). 
XTALD2 is cleared to 0 by hardware reset, but is not 
changed by firmware reset. 

FIG. 41 is a description of DSPSL (DSP Selection) 
register. This register selects the DSP configuration. 

C2ML—bit 7—C2 MSB to LSB “1” sets the direction of 
incoming erasures at pin C2PO to upper erasure followed by 
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lower erasure. “0” sets the direction to lower erasure fol- 
lowed by upper erasure. C2ML is cleared to “0” by hardware 
reset, but is not changed by firmware reset. 

SEL160—bit 6—Select 16 Offset “1” selects 16 bit- 
clocks per channel, with offset by one after LRCK. “0” does 
not select 16 bit-clocks with offset. SEL160 is cleared to “0” 
by hardware reset, but it is not changed by firmware reset. 

LCHL—bit 5—Left Channel Polarity “1” selects left 
channel as active if pin LRCK is “1”. “0” selects left channel 
is active if pin LRCK is “0”. LCHO is set to “1” by hardware 
reset, but is not changed by firmware reset. 

SEL16—bit 2—Select 16 “1” selects 16 bit-clocks per 
channel. “0” does not select 16 bit-clocks. SEL16 is set to 
“1” by hardware reset, but is not hanged by firmware reset. 

DIR—bit 1—Data Direction “1” selects the rising edge of 
DBCK for latching incoming data at pin DSDATA. “0” 
selects the falling edge of DBCK for latching DSDATA. If 
the incoming data at pin DSDATA changes at the falling 
edge of DDBCK, use the rising edge for latching if DSDATA 
changes at the rising edge of DBCK, use the falling edge for 
latching. EDGE is set to 1 by hardware reset, but is not 
chanted by firmware reset. 

FIG. 42 DSP SELECTION TABLE shows the settings for 
various DSPs. the default setting after hardware reset is 
00100101 (Matsushita MN66261). The setting of DSPSL is 
not changed by firmware reset. 

FIG. 43 is a description of the HCON/UACL register. 

FIG. 44 is a description of the DSPSL register. 

FIGS. 45, 46 and 47 are descriptions of the UACL, 
UACH and UACU Microcontroller-RAM Address Counter 
which forms a 20-bit counter that controls the buffer address 
for transfers between the microcontroller and RAM. The 
counter can be set to any physical location in the buffer 
RAM, and contains enough bits to support larger RAM sizes 
in future revisions. After waiting for busy flag URTBSY to 
be low in register HDDIR (1Fh.7), the microcontroller 
writes the RAM starting address into the counter. UACL, 
UACH, and UACU are incremented automatically each time 
a byte is read or written. See the description of registers 
RAMRD, (1Eh), RAMWR (1Eh), and flag URTBSY in 
register HDDIR (1Fh.7). UACH should always be written 
after UACL is written, and UACU should always be written 
after UACH is written. UACL, UACH and UACU are 
undefined following hardware reset or firmware reset. 

FIG. 48 is a description of the RAMRD/RAMWR RAM 
Read and Write registers. The microcontroller accesses the 
buffer RAM by reading from the RAMRD register or writing 
to the RAMWR register. To initialize a read or write 
sequence, the microcontroller waits for busy flag URTBSY 
to be low in register HDDIR (1Fh.7), then writes the RAM 
starting address into the counter formed by UACL (1Ch), 
UACH (1Dh), and UACU (2Dh). Reading RAMRD causes 
events (1), (2) and (3) to occur in the following order: 
(1)—-data previously stored in RAMRD is transferred to the 
microcontroller; (2)—RAM data at the counter address is 
transferred to the RAMRD register; and (3) counter UACL, 
UACH, and UACU is incremented and flag URTBSY 
cleared. After the RAM starting address is written to the 
counter, the first read of register RAMRD will transfer an 
INVALID byte to the microcontroller, followed by the 
starting byte from the RAM to the RAMRD register. The 
invalid byte remains from a previous access, or from power- 
up. Because the counter is automatically incremented, 
sequential reads can be used without writing new addresses 
into UACL, UACH, and UACU. However, flag URTBSY 
should be checked before each sequential read from 
RAMRD to make sure that events (1), (2) and (3) in the 
previous transfer from RAM to RAMRD have completed. 
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Writing RAMWR causes the following events to occur in 
the following order: (1)—data is transferred from the micro- 
controller to register RAMWR; (2)—data is transferred from 
RAMWR to the RAM (at the counter address); and (3)— 
counter UACL, UACH and UACU is incremented and flag 
URTBSY is cleared. After the RAM starting address is 
written to the counter, the first write to register RAMWR 
will transfer a VALID byte to the RAM. Because the counter 
is automatically incremented, sequential writes can be used 
without writing new addresses into UACL, UACH and 
UACU. However, flag URTBSY should be checked before 
each sequential write to RAMWR to make sure that events 
(1)-(3) in the previous transfer from RAMWR to RAM have 
completed. The contents or RAMRD and RAMWR are 
undefined following hardware reset or firmware reset. 

FIG. 49 is a description of HDDIR Host data Direction 
Register. This register provides microcontroller and host 
transfer flags and control. 

URTBS Y—tead bit 7—Microcontroller to RAM Transfer 
Busy “1” indicates that the previous microcontroller-RAM 
transfer is in progress. “O” indicates that the microcontroller- 
RAM transfer logic is not busy. URTBSY is cleared to 0 by 
hardware reset or firmware reset. 

CS13—tead bit 6 Chip Select 1 and 3 “1” indicates that 
input pins CSIFX- and CS3FX-became active at the same 
time, indicating present of a non-ATA host adaptor. “0” 
indicates normal operation. Flag CS13 can be used to 
support non-ATA host adapters that have lines CS1FX- and 
CS3FX-connected together. With this adaptor configuration, 
host writes to the ATAPI Features Register (1F1) will set flag 
CS13, allowing firmware to respond appropriately to adapt- 
ers that do not support separate CS3FX-addressing. CS13 is 
cleared to 0 by hardware reset, but is not changed by 
firmware reset. 

UDTRG and UDATA—write bits 7 and 
6—Microcontroller Data Trigger/Select are normally set to 
“0”, selecting data transfers from the buffer RAM to the 
host. Setting UDATA to “1” enables microcontroller writes 
to data registers UDTAO~7 (40h-47h), and allows high- 
speed 8-bit or 16-bit data transfers from UDTAO-7 to the 
host. Writing to UDTRG triggers the transfer from 
UDTA0-7 to the host. This type of transfer is efficient for the 
small amounts of data (up to eight bytes can be transferred 
at a time). Registers IFSTAT, IFCTRL, DBCL, DBCH, 
DTTRG, and DTACK (01h—03h, 06h and 07h) are used in 
the same way as a RAM to host transfer, except flag DTENb 
in IFSTAT has no meaning. However, registers DACL and 
DACH are not used. After enabling control bit DOUTEN (in 
register IFCTRL), loading DBCL, DBCH and setting 
UDATA to 1, and writing to registers UDTAO-7, the micro- 
controller writes to register DTTRG. Next, the microcon- 
troller sets UDTRG to 1, followed by 0, to trigger the 
FIFO-ready transfer logic. The host will receive data begin- 
ning with UDTAO and ending with UDTA7. UDTRG and 
UDATA are cleared to 0 by hardware reset or firmware reset. 

HOST16—write bit 5—Host 16-bit Select “1” selects 
16-bit Data reads and Packet FIFO writes (at host register 
1FOh). “0” selects 8-bit Data reads and packet-FIFO writes. 
because 8-bit data transfers do not conform to the ATAPI 
specification, HOST16 should normally be set to 1. HOST16 
is cleared to 0 by hardware reset or firmware reset Note: For 
16-bit data reads, the number of WORDS minus one should 
be loaded into DBCL and DBCH. For 8-bit data reads, the 
number of BYTES minus one should be loaded into DBCL 
and DBCH. 

FIG. 50 is a list of the only values that should be written 
to HDDIR—write bits 4, 3, 2, 1 and 0, following hardware 
or firmware reset. 
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FIG. 51 is a description of the HICTL Host Interface 
Control register. This register provides control of the host 
interface. 

HICTL—it 7 should only be set to “0” This bit is cleared 
to 0 by hardware reset but is not changed by firmware reset. 

PDIAGEN—bit 6—Pin HPDIAG- Enable “1” sets pin 
HPDIAG- to the active-low state. “O” clears HPDIAG- to 
the high-impedance state (HPDIAG- is an open-drain pin). 
PDIAGEN is automatically cleared to 0, clearing pin 
HPDIAG- to high-impedance by hardware reset command 
Execute Drive Diagnostics (ATA opcode 90h), or ATA Soft 
Reset (SRST). After PDIAGEN is automatically cleared, pin 
HPDIAG- should be set following the timing in ATAPI and 
ATA specification. Execute Drive Diagnostics and ATA Soft 
Reset clear PDIAGEN even if the drive is not selected in the 
ATAPI Drive Select Register. PDIAGEN is not changed by 
firmware reset. 

DASPEN—bit 5—Pin HDASP- Enable “1” sets pin 
HDASP- to the active-low state. “0” clears HDASP- to the 
high-impedance state (HDASP- is an open drain pin). 
DASPEN is automatically cleared to 0, clearing pin 
HDASP- to high-impedance by hardware reset command 
Execute Drive Diagnostics (ATA opcode 90h), or ATA Soft 
Reset (SRST). After DASPEN is automatically cleared, pin 
HDASP- should be set following the timing in ATAPI and 
ATA specification. Execute Drive Diagnostics and ATA Soft 
Reset clear DASPEN even if the drive is not selected in the 
ATAPI Drive Select Register. DASPEN is not changed by 
firmware reset. 

CLRBSY—bit 4—Clear BSY “1” prepares the clearing 
logic for flag BSY in the ATAPI Status Register. Note: BSY 
is actually cleared by the FOLLOWING write to register 
HICTL. “0” should be written to CLRBSY during the 
FOLLOWING write. Whenever flag BSY in the ATAPI 
Status Register (1F7h) is set, whether automatically or by 
control bit SETBSY. BSY should be cleared (using 
CLRBSY) as soon as allowed by the ATAPI and ATA 
specifications. See the description of control bit SETBSY. 
CLRBSY is not changed by firmware reset. 

SETBSY—bit 3—Set BSY “1” prepares the setting logic 
for flag BSY in the ATAPI Status Register. Note: BSY is 
actually set by the FOLLOWING write to register HICTL. 
“0” should be written to SETBSY during the FOLLOWING 
write. Writing 1 to SETBSY activates the microcontroller 
interrupt, if enabled by control bit IDEIEN in register 
UMISC (2Eh.7). Flag BSY is automatically set, and the 
microcontroller interrupt activated, by hardware reset, com- 
mand Execute Drive Diagnostics (ATA opcode 90h), ATA 
Soft Reset (SRST), or any command written to the ATAPI 
Command Register (host register 1F7h). SETBSY and flag 
BSY are not changed by firmware reset. 

SCOD—bit 2—Select command Packet or Data “1” 
selects the Command-Packet FIFO to be addressed by the 
ATA data port (host address 1FOh). “0” selects the buffer 
RAM to be addressed by the ATA data port. SCOD is cleared 
to 0 by hardware reset, but is not changed by firmware reset. 
IORDYEN—bit 1—Pin IORDY Enable “1” allows the data 
transfer logic to de-assert pin IORDY whenever necessary. 
“0” does not allow IORDY to be de-asserted IORDY acts as 
an open-drain pin). If IORDYEN is set high, pin IORDY 
will be de-asserted to 0 whenever it is necessary to slow 
down the data transfer rate to match the capability of the 
CD-ROM drive. The capability of the drive depends on the 
RAM configuration and crystal frequency. Note” Some 
systems will not work properly if pin IORDY is de-assened 
IORDYEN is set to 1 by hardware reset but is not changed 
by firmware reset. 
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IOCS16EN—bit 0 Pin IOCS16- Enable “1” allows pin 
IOCS16- to become active low during 16-bit reads from the 
buffer RAM or 16-bit writes to the Packet FIFO (at host 
register 1FOh). Note: Control bit HOST16 in register 
HDDIR (1Fh.5) must also be enabled. “0” does not allow 
IOCS16- to be asserted (IOCS16- is an open drain pin). 
Because both IOCSI6EN and HOST16 must be enabled to 
allow assertion of pin IOCS16-, IOCS16EN can always be 
set to 1. In this case, HOST16 will correctly control pin 
IOCS16- and all 16-bit transfer logic. To conform to the 
ATAPI specification, 16-bit data transfers should be used. 
IOCS16EN is cleared to 0 by hardware reset, but is not 
changed by firmware reset. 

FIG. 52 is a description of SUBC2 Subcode Control-2 
register. This register provides control of the subcode inter- 
face. 

NOPQ—bit 3 No P-data or Q-data, “1” clears (to 0) bits 
7 and 6 (P-data and Q-data) of subcode data that is written 
to the buffer RM. “0” allows the P-data and Q-data bits to 
be included in subcode data that is written to the buffer 
RAM. NOPQ is cleared to 0 by hardware reset, but is not 
changed by firmware reset. 

FIG. 53 is a description of the DSP Subcode Clock 
TABLE. 

CDSP2, CDSP1, and CDSP0—bits 2, 1 and 0—DSP 
Subcode Clock Select, if subcode is buffered the DSP clock 
select bits must be set as shown in the figure, in order to 
match the subcode data rate. Only the combinations shown 
in the table should be used. DSP2-0 only control subcode 
clocking logic, and do not need to be set unless subcode is 
written to the buffer RAM. CDSP2-9 are cleared to 0 by 
hardware reset, but are not changed by firmware reset. 

FIG. 54 is the STATS Status of subcode register. If read 
from, STATS provides status of the subcode interface. If 
written to, STATS clears the subcode interrupt (if enabled) 
and status flags. 

STATS bits 7, 6, 5, 4 and 3 are undefined. During reads 
of STATS by the microcontroller, bits 7-3 are undefined, and 
can be high or low. 

MISSY—bit 2—Missing Subcode Sync “1” indicates a 
missing subcode sync condition. “0” indicates subcode sync 
is not missing. Flag SINT in register RSSTAT (2Fh.4) is set 
(to 1) whenever flag MISSY is set. If enabled by control bit 
SCIEN in register SUBCD (2Ch.4), a microcontroller inter- 
rupt is also activated when MISSY is set. SINT, interrupt, 
and MISSY are cleared by writing any value to STATS. 

SBKEND—bit 1—Normal End of Subcode Block “1” 
indicates a normal subcode block end. “0” indicates no 
normal subcode block end. Flag SINT in register RSSTAT 
(2Fh.4) is set (to 1) whenever flag SBKEND is set. If 
enabled by control bit SCIEN in register SUBCD (2Ch.4), a 
microcontroller interrupt is also activated when SBKEND is 
set. SINT, interrupt, and SBKEND are cleared by writing 
any value to STATS. 

SILSY—bit 0—IIlegal Subcode Syne “1” indicates a 
normal subcode block end. “0” indicates no normal subcode 
block end. Flag SINT in register RSSTAT (2Fh.4) is set (to 
1) whenever flag SILSY is set. If enabled by control bit 
SCIEN in register SUBCD (2Ch.4), a microcontroller inter- 
rupt is also activated when SILSY is set. SINT, interrupt, and 
SILSY are cleared by writing any value to STATS. 

FIGS. 55 and 56 are descriptions of DBACL and DBACH 
Data Transfer Block Registers. In order to free the micro- 
controller from calculating 2352-byte address boundaries, 
the buffer RAM is partitioned into blocks. Registers DBACL 
and DBACH control the RAM block number of the data to 
be transferred, while counters DACL and DACH (04h and 
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05h) control the address relative to the beginning of the 
RAM block specified by DBACL and DBACH. The RAM 
block number is not incremented automatically, and must be 
set before each block transfer to the host begins. DBACL 
and DBACH contain enough bits to support larger RAM 
sizes in future revisions. For data transfer information, see 
the description of registers IFCTRL, DBCL, DBCH, 
a=DACL, DACH DTTRG, and DTACK (01h-O07h). 
DBACH should always be written after DBACL is written. 
DBACL, DBACH are cleared to 00,00h by hardware reset 
or firmware reset. 

FIGS. 57 and 58 are descriptions of SBKL and SBKH 
Subcode Write Block Registers. After the appropriate inter- 
rupt occurs, registers SBKL and SBKH point to the RAM 
block number of subcode that is available for transfer to the 
host Also, the number in SBKL and SBKH plus 1 points to 
the RAM block number of the buffer area for writing 
incoming subcode. Register SBADR (23h) controls the 
write location within each block. The RAM block number in 
SBKL and SBKH is incremented automatically, and only 
needs to be updated by the microcontroller in order to 
overwrite a discarded block. SBKL and SBKH contain 
enough bits to support larger RAM sizes in future revisions. 
If subcode sync and data sync are synchronized by enabling 
control bit SDSS in register CTRLW (10h.5), SBKL and 
SBKH should be read soon after the decoder interrupt occurs 
(bit DECIb in register IFSTAT becomes 0). In this case, 
SBKL and SBKH remain valid until the next data sync 
occurs (see the description of register STAT3 for checking 
the valid time period). If subcode sync and data sync are not 
synchronized, SBKL and SBKH should be read soon after 
the subcode interrupt occurs (bit MISSY, SBKEND, or 
SILSY in register STATS becomes 1). In this case, SBKL 
and SBKH remain valid until the next subcode interrupt 
occurs. The value read from the lower 9 bits of SBKL and 
SBKH during the valid time period identifies the RAM 
block that is available for transfer to the host. During reads 
of SBKH by the microcontroller, bits 7-1 are undefined, and 
can be high or low. SBKH, SBKL are cleared to 00,00h by 
hardware reset or firmware reset, causing buffering of 
incoming subcode data to begin at block number 1. 

FIGS. 59 and 60 are descriptions of WBKL and WBKH 
Decoder and Buffer-Write Block Counter registers. In order 
to free the microcontroller from calculating 2352-byte 
address boundaries, the buffer RAM is partitioned into 
blocks. Registers WBKL and WBKH point to the RAM 
block number of the data to be processed by the error 
correction logic. Also, the number in WBKL and WBKH 
plus 1 points to the RAM block number of the buffer area for 
writing incoming serial data. Registers WAL and WAH 
(08h/OAh and 09h/OBh) control the write location within 
each RAM block. The RAM block number in WBKL and 
WBKH is incremented automatically, and only needs to be 
updated by the microcontroller in order to overwrite a 
discarded block. WBKL and WBKH contain enough bits to 
support larger RAM sizes in future revisions. WBKL and 
WBKH should be read soon after the decoder interrupt 
occurs (bit DECIb in register IFSTAT becomes 0). WBKL 
and WBKH remain valid until the next sync occurs (see the 
description of register STAT3 for checking the valid time 
period). The value read from the lower 9 bits of WBKL and 
WBKH during this valid time period identifies the RAM 
block that is available for transfer to the host. During reads 
of WBKH by the microcontroller, bits 7-1 are undefined, 
and can be high or low. WBKH, WBKL are cleared to 
00,00h by hardware reset or firmware reset, causing buff- 
ering of incoming serial data to begin at block number 1. 
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FIG. 61 is a description of RAMCF RAM Configuration 
Register. This register provides control of the RAM interface 
configuration. Each control bit written to this register can 
also be read by the microcontroller. 

RFTYP—tbit 7 Refresh Type, “1” selects CAL before 
RAM DRAM refresh. “0” selects CAS only DRAM refresh. 
RFTYP is cleared to 0 by hardware reset, but is not changed 
by firmware reset. 

RAMCLR—bit 6—RAM Clear Enable “1” enables RAM 
clearing, filling all locations in the buffer RAM. “0” disables 
RAM clearing. To clear the RAM, first write the clear data 
value (normally 00h) to register RAMWR (1Eh). Next, write 
00h to registers UACL, UACU, and UACH (1Ch, 1Dh and 
2Dh). Enable RAMCLR to begin writing the contents of 
RAMWR to each RAM location. When all RAM locations 
have been filled, RAMO (bit 5) will change from 0 to 1. After 
RAM clearing has completed, the microcontroller should 
clear RAMCLR to 0. RAMO will return to 0 when RAM- 
CLR is disabled. If enabled by control bit RPEN, the correct 
parity bit will be written to all locations during RAM 
clearing. RAMCLR is cleared to 0 by hardware reset, but is 
not changed by firmware reset. 

RAMO—Dit 5—RAM Clear Flag (read only) “1” indi- 
cates that the RAM address has wrapped around beyond 
00,00,00h, and that RAM clearing has completed. “0” 
indicates that the RAM clearing has not completed or is 
disabled. RAMO is cleared to 0 by hardware reset, but is not 
changed by firmware reset. 

UHILO—bit 4—Host High-Low Swap “1” enables byte 
swaps for reads from the buffer RAM to the host, causing 
odd bytes to be read before even bytes. “0” disables byte 
swap, causing even bytes to be read before odd bytes. Byte 
swapping is not normally needed for ATAPI operation. 
UHILO is cleared to 0 by hardware reset, but is not changed 
by firmware reset. 

RPEN—bit 3 RAM Parity Enable “1” enables parity 
checking, and parity interrupt, of DRAM data. “0” disables 
parity checking and parity interrupt. Enabling RAM parity 
allows defective DRAMS to be detected. RAM clearing, 
using control bit RAMCLR, should be completed before 
RAM parity is enabled. If a parity error is detected, flag 
PARINT will be set to 1 in register RSSTAT (2Fh.3) and the 
microcontroller interrupt pin will be activated. Flag PARINT 
and the interrupt are cleared by clearing RPEN to 0. RPEN 
is cleared to 0 be hardware reset, but is not changed by 
firmware reset. 

FIG. 62 is a table of RCF2, RCF1 and RCFO—bits 2, 1 
and 0—RAM Configuration. Only the settings shown in the 
RAM Configuration Table should be used. RCF2, RCF1, 
and RCFO are cleared to 0 by hardware reset, but are not 
changed by firmware reset. 

FIG. 63 is a description of MEMCF (Memory Layout 
Configuration) register. This register provides control of the 
RAM layout configuration. 

MEMCF bits 7, 6, 5, and 4 must always be set to 0. 
MEMCF bits 7,6, 5, and 4 are cleared to 0 by hardware reset, 
but are not changed by firmware reset. 

PURG—bit 3—Data FIFO Purge “1” purges the RAM to 
Host Data FIFO. “0” disables the FIFO purge logic. This bit 
should be cleared to 0 except during the purge operation. 
PURG is cleared to 0 by hardware reset, but is not changed 
by firmware reset. 

IORDYF—bit 2—Pin IORDY Fast Enable “1” enables 
output pin IORDY to be de-asserted to 0 without qualifica- 
tion by input pin HRD-. “0” disables unqualified 
de-assertion of pin IORDY. This bit speeds up de-assertion 
of pin IORDY by ignoring the state of pin HRD-. However, 
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unqualified de-assertion of IORDY violates the ATA 
specification, and may interfere with normal operation of 
many systems. IORDYF is cleared to 0 by hardware reset, 
but is not changed by firmware resets 

FIG. 64 is a description of MLY1 and MLY0—tits 1 and 
0—Memory Layout Configuration. Following hardware 
reset, the memory layout configuration should be set as 
shown in the figure. Only the settings shown in the Memory 
Layout Configuration Table should be used. Normally, all 
auxiliary blocks are buffered (MLY1=1 and MLY0=1). If 
only the last 2 auxiliary blocks are buffered, the configura- 
tion must be changed whenever data transfer sizes above 
2048 bytes are required. MLY1 and MLYO0 ARE CLEARED 
TO 0 BY HARDWARE RESET, but are not changed by 
firmware reset. 

FIG. 65 is a description of SUBCD Subcode Control 
register. This register provides control of the subcode inter- 
face. 

SBXCK—bit 7—Subcode External Clock “1” selects an 
external clock from pin EXCK to be used by the subcode 
logic. “O” selects an internal clock to be used by the subcode 
logic. SBXCK is cleared to 0 by hardware reset, but is not 
changed by firmware reset. 

SCEN—bit 6—Subcode Enable “1” enables the subcode 
logic. “0” disables the subcode logic. SCEN is cleared to 0 
by hardware reset, but is not changed by firmware reset. 

SCKB2—bit 5—Subcode Clock Divide By 2 “1” enables 
the divide by 2 logic (for internal or external clock). “0” 
disables the divide by 2 logic. SCKB2 is cleared to 0 by 
hardware reset, but is not changed by firmware reset. 

SCIEN—bit 4—Subcode Interrupt Enable “1” enables 
activation of subcode interrupts to the microprocessor. “0” 
disables subcode interrupts. SCIEN is cleared to 0 by 
hardware reset, but is not changed by firmware reset. 

EXINV—bit 3—External Clock Invert Select “1” selects 
an inverted output clock at pin EXCK if EXCK is set as an 
output. “0” selects a non-inverted clock. EXINV is cleared 
to 0 by hardware reset, but is not changed by firmware reset. 

EXOP—bit 2—Pin EXCK Operation “1” sets EXCK as 
an output pin. “O” sets EXCK as an input pin. EXOP is 
cleared to 0 by hardware reset, but is not changed by 
firmware reset. 

FIG. 66 is SBSEL1 and SBSELO—bits 1 and 0O—Subcode 
Format Select Table. The subcode format should be set 
according to the figure. SBSEL1 and SBSEL0 are cleared to 
0 by hardware reset, but are not changed by firmware reset. 

FIG. 67 is a description of UMISC (Miscellaneous Micro- 
controller Control) register. This register provides miscella- 
neous flags and control bits. 

PDIAGb—tead-bit 1—Pin HPDIAG- Flag “1” indicates 
that open-drain pin HPDIAG- is high (inactive). In this case, 
both master and slave drives are de-asserting pin HPDIAG-. 
“0” indicates that pin HPDIAG- is low (active) In this case, 
either the master or slave drive is setting pin HPDIAG- to 
active-low. 

DASPb—tread-bit 0—Pin HDASP- Flag “1” indicates 
that open-drain pin HDASP- is high (inactive). In this case, 
both master and slave drives are de-asserting pin HDASP-. 
“0” indicates that pin HDASP- is low (active). In this case, 
either the master or slave drive is setting pin HDASP- to 
active-low. 

IDEIEN—write-bit 7—IDE Interrupt Enable “1” enables 
activation of IDE (ATA) interrupts to the microprocessor. 
“Q” disables activation of IDE (ATA) interrupts. IDE inter- 
rupts (if enabled) are activated, and flag SRST, CMD, 
DIAGCMD, or HRST set in register RSSTAT (2Fh.7,6,5,0), 
whenever the BSY flag in the ATAPI status register is set 
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automatically by: 1 written to bit SRST (Soft Reset) in the 
ATAPI Device Control Register (host address 3F6h) in the 
master or slave drive. Note: The BSY flag and IDE interrupt 
(if enabled) cannot be cleared while SRST is set to 1. Any 
command written to the ATAPI Command Register (host 
address 1F7h) while the drive is selected. Command 
Execute Drive Diagnostics (ATA opcode 90h) written to the 
master or slave drive. Note: if opcode 90h is written while 
the drive is selected, both flags CMD and DIAGCMD will 
be set. 

Hardware Reset (however, hardware reset clears 
IDEIEN). Writing 1 followed by 0 to SETBSY in register 
HICTL (20h.3) sets BSY and activates the interrupt (if 
enabled by IDEIEN) but does not set a status flag. The BSY 
flag and IDE interrupt are cleared by writing 1 followed by 
0 to control bit CLRBSY in register HICTL (20h.4). IDEIEN 
is cleared to 0 by hardware reset, but is not changed by 
firmware reset. 

UMISC write-bit 6 should always be cleared to 0. 

DRVEb—write-bit 5—Drive Enable “1” disables selec- 
tion of the drive, whether bit DRV in the ATAPI Drive Select 
Register (host address 1F6h) is 0 or 1. “0” enables selection 
of the drive if bit DRV matches the setting of DRV1b in 
register UMISC. DRVIB is set to 0 (active) by hardware 
reset, but is not changed by firmware reset. 

DRV1b—write-bit 4—Drive 1 “1” sets the drive to be 
selected when bit DRV in the ATAPI Drive Select Register 
is set to 0 (drive 0). “0” sets the drive to be selected when 
bit DRV in the ATAPI Drive Select Register is set to 1 (drive 
1). DRVI1b is set to 0 (drive 1) by hardware reset, but is not 
changed by firmware reset. 

HINTRQ—write-bit 3—Host Interrupt Request “1” sets 
pin HIRQ high if the drive is selected and NIEN (Interrupt 
Enable) is enabled in the ATAPI Device Control Register 
(host address 3F6h). “0” clears pin HERQ (to 0) if the drive 
is selected and NEIEN is enabled. HINTRQ is automatically 
cleared to 0 by the following: Hardware reset, 1 written to 
bit SRST (Soft Reset) in the ATAPI Device Control Register 
(host address 3F6h) in the master or slave drive, any 
command written to the ATAPI Command Register (host 
address 1F7h) while the drive is selected, and a read from the 
ATAPI Status Register (host address 1F7h) while the drive 
is selected. HINTRQ is not changed by firmware reset, or by 
reads from the ATAPI Alternate Status Register (host 
address 3F6h). If the drive is not selected, or if NIEN is 
disabled (cleared to 1), pin HIRQ becomes high-impedance. 

UMISC write-bits 2, 1, and 0 should always be set to 0. 

FIG. 68 is a description of RSSTAT—Reset, IDE and 
Subcode Status Register RSSTAT (Reset, IDE, and Subcode 
Status) register provides status flags for reset, IDE, and 
subcode logic. 

SRSTF—bit 7—Soft Reset Flag “1” indicates that 1 has 
been written to bit SRST (Soft Reset) in the ATAPI Device 
Control Register (host address 3F6h) in the master or slave 
drive. “0” indicates that 1 has not been written to bit SRST. 
The BSY flag is set, and IDE interrupt to the microcontroller 
activated (if enabled), whenever SRST is set. BSY and IDE 
interrupt cannot be cleared until SRST is cleared to 0 
(however, the IDE interrupt can be disabled). After SRST is 
cleared, the BSY flag and IDE interrupt are cleared by 
writing 1 followed by 0 to control bit CLRBSY in register 
HICTL (20h.4). Flag SRSTF is cleared to 0 by hardware 
reset, but is not changed by firmware reset. 

CMD—bit 6—ATA Command “1 ” indicates that a com- 
mand has been written to the ATAPI Command Register 
(host address 1F7h) while the drive was selected. “0” 
indicates that a command has not been written. The BSY hag 
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is set, and IDE interrupt to the microcontroller activated (if 
enabled), whenever a command is written to the ATAPI 
Command Register while the drive is selected. The BSY flag 
and IDE interrupt are cleared by writing 1 followed by 0 to 
control bit CLRBSY in register HICTL (20h.4). CMD is 
cleared to 0 by hardware reset, but is not changed by 
firmware reset. 

DIAGCMD—bit S—Execute Drive Diagnostics Com- 
mand “1” indicates that the ATA command Execute Drive 
Diagnostics (ATA opcode 90h) has been written to the 
master or slave drive. “O” indicates that Execute Drive 
Diagnostics has not been written. The BSY flag is set, and 
IDE interrupt to the microcontroller activated (if enabled), 
whenever Execute Drive Diagnostics is written to the ATAPI 
Command Register. If opcode 90h is written while the drive 
is selected, both flags CMD and DIAGCMD will be set. The 
BSY flag and IDE interrupt are cleared by writing 1 fol- 
lowed by 0 to control bit CLRBSY in register HICTL 
(20h.4). DIAGCMD is cleared to 0 by hardware reset, but is 
not changed by firmware reset. 

SINT—bit 4—Subcode Interrupt Flag “1” indicates that 
flag MISSY, SBKEND, or SILSY 5 has been set in register 
STATS (22h.2,1,0). “0” indicates that flag MISSY, 
SBKEND, or SILSY has not been set. If enabled by control 
bit SCIEN in register SUBCD (2Ch.4), a microcontroller 
interrupt is activated when SINT is set. SINT, interrupt, and 
the flag in register STATS are cleared by writing any value 
to STATS. SINT is cleared to 0 by hardware reset or 
firmware reset. 

PARINT—bit 3—Parity Interrupt Flag “1” indicates that 
a parity error has been detected in the DRAM. “0” indicates 
that a parity error has not been detected. If enabled by 
control bit RPEN in register RAMCF (2Ah.3), a microcon- 
troller interrupt is activated when PARINT is set. PARINT 
and the interrupt are cleared by writing 0 to RPEN. PARINT 
is cleared to 0 by hardware reset, but is not changed by 
firmware reset. 

RST—bit 2—Reset Flag “1” indicates that the device is 
currently being reset. “O” indicates that the device is not 
currently being reset. RST allow the hardware reset to be 
monitored (if the microcontroller is not reset at the same 
time). 

URST—bit 1—Firmware Reset Flag “1” indicates that 
the current or most recent reset was activated by writing to 
the register RESET (OFh). “0” indicates that register RESET 
has not been active. The first read of RSSTAT following the 
end of the firmware reset cycle clears URST to 0. URST is 
cleared to 0 by hardware reset. 

HRST—bit 0—Hardware Reset Flag indicates that the 
current or most recent reset was activated by hardware reset 
(pin RESET-). “0” indicates that pin RESET- has not been 
set to 0. The BSY flag is set whenever hardware reset is 
activated. The BSY flag and IDE interrupt are cleared by 
writing 1 followed by 0 to control bit CLRBSY in register 
HICTL (20h.4). The first read of RSSTAT following the end 
of the hardware reset cycle clears HRST to 0. HRST is not 
changed by firmware reset. 

FIGS. 69-75 are descriptions of ATAPI Task File Regis- 
ters (TR). The Task File Register bits are labeled according 
to the ATAPI Specification. 

FIG. 69 is a description of ATFEA and ATERR. 

ATFEA—Output from Features TR—The host writes this 
register at host address 1F1h. 

ATERR—Input to Error TR—The host reads this register 
at host address 1F 1h. 

FIG. 70 is a description of ATINT—I/O of Interrupt 
Reason TR—The host accesses this register at host address 
1F2h. (1F2h is Sector Count in ATA Specification.) 
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FIG. 71 is a description of ATSPA—Spare TR (unused in 
ATAPI Specification)—The host accesses this register at 
host address 1F3h. (1F3h is Sector Number in ATA 
Specification.) 

FIG. 72 is a description of ATBLO—I/O of Byte Count 
Low TR—The host accesses this register at host address 
1F4h. (1F4h is Cylinder Low in ATA Specification.) 

FIG. 73 is a description of ATBHI—I/O of Byte Count 
High TR—The host accesses this register at host address 
1F5h. (1F5h is Cylinder High in ATA Specification.) 

FIG. 74 is a description of ATDRS—I/O of Drive Select 
TR—The host accesses this register at host address 1F6h. 
Bit 4, DRV, selects drive 1 when high or drive 0 when low. 
Bit 6, L, should be set to 1 to select LBA (not CHS) 
addressing. Bit 4 (DRV) is set to 1 by hardware reset. (1F6h 
was Drive/Head Select in ATA Specification.) 

FIG. 75 is a description of ATCMD—Output from Com- 
mand Register—The host writes this register at host address 
1F7h. 

ATSTA—Input to Status Register—The host reads this 
register at host address 1F7h. 

FIGS. 76-83 are descriptions of the Microcontroller to 
Host Data Transfer Registers. The microcontroller writes up 
to eight bytes of data to be transferred to UDTAO-7. The 
host reads these registers as data at host address 1FOh. 
UDTAO is read first, and UDTA7 last. See the description of 
control bits UDTRG and UDATA in register HDDIR (1Fh.7, 
6). 

What is claimed is: 

1. An optical drive controller to control the communica- 
tion of data between a storage medium in an optical drive 
device and a host computer via an IDE/ATA data bus, said 
data bus for receiving and transmitting data between said 
controller and said host computer, said optical drive device 
having drive electronics, said optical drive controller com- 
prising: 

a storage medium interface for receiving data from said 

storage medium; 


data error detection and correction circuitry, said detec- 
tion and correction circuitry including: 
error correction circuitry for performing error correc- 
tion on data received from said interface and gener- 
ating corrected data, and 
error detection circuitry for detecting errors in data 
prior to transmission to said host computer; and 


a host interface connecting said host computer and said 
optical drive controller directly via an IDE/ATA data 
bus, said host interface operable to receive data 
addresses and commands from said host computer and 
transmit data to said host computer, and including an 
ATA command block register address at which to store 
sequentially contiguous bytes of command data, that 
are part of the same command, transmitted from the 
host computer in a single command transfer. 

2. An optical drive controller to control the communica- 
tion of data between a storage medium in an optical drive 
device and a host computer via an IDE/ATA data bus, said 
data bus for receiving and transmitting data between said 
controller and said host computer, said optical drive device 
having drive electronics, said optical drive controller com- 
prising: 

a storage medium interface to receive data from said 

storage medium; 

data error detection and correction circuitry coupled to 
said storage medium interface, to provide error free 
data for transmission to said host computer; and 
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a host interface connecting said host computer and said 
optical drive controller directly via an IDE/ATA data 
bus, said host interface including a data port operable 
to receive data addresses and commands from said host 
computer and transmit data to said host computer, a 
multibyte command packet buffer operable, per 
command, to store sequentially contiguous bytes of 
command information received through the data port in 
a single command transfer. 

3. An optical drive controller to control the communica- 
tion of data between an optical storage medium in an optical 
drive device and a host computer via an IDE/ATA data bus, 
said data bus operable to receive and transmit data between 
said optical drive controller and said host computer, 
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wherein the improvement comprises: 


a host interface to connect said host computer and said 


optical drive controller directly via said IDE/ATA data 
bus, said host interface including an ATA register 
address at which to receive data addresses and com- 
mands from said host computer and transmit data to 
said host computer, and a multibyte command packet 
buffer operable to sequentially store a packet of con- 
tiguous bytes of command information received 
through the ATA register address in a single command 
transfer. 


